C语言连接数据库

文章目录

接下来我简单的介绍一下怎么用C语言连接数据库。

  1. 初始化数据库
  2. 创建数据库连接
  3. 执行增删改查语句
  4. 关闭数据库连接

一、初始化数据库

cpp 复制代码
// 数据库初始化
MYSQL mysql;
MYSQL* ret1 = mysql_init(&mysql);
if (ret1 == nullptr)
{
    std::cerr << "init_error" << std::endl;
    exit(-1);
}

/*****************
返回值:
	如果没有足够的内存来分配新对象,则为空。
*****************/

二、创建数据库连接

cpp 复制代码
// 数据库连接
MYSQL* ret2 = mysql_real_connect(&mysql, host.c_str(), user.c_str(), passwd.c_str(), db.c_str(), port, nullptr, 0);
if (ret2 == nullptr)
{
    std::cerr << "connect_error" << std::endl;
    exit(-1);
}

/*****************
参数:
	1、MYSQL *mysql       ===> 创建的数据库变量
	2、const char *host   ===> 主机号, 如果是本地可以用"127.0.0.1"
	3、const char *user   ===> 用户名
	4、const char *passwd ===> 密码
	5、const char *db     ===> 数据库名
	6、unsigned int port  ===> 端口号
	7、剩下的两个参数一个置空,一个置0就行
返回值:
	如果没有足够的内存来分配新对象,则为空。
*****************/

三、执行增删改查语句

这个部分需要分成两类:增删改、查。增删改只需要考虑这个语句执行的是否是正常的,但是查询这个操作还需要通过返回值得到查询的结果。

1、增删改

cpp 复制代码
// 执行增删改
std::string sql = "insert into user (name, age) values ('wangwu', 19);";
int ret3 = mysql_query(&mysql, sql.c_str());
if (ret3)
{
	std::cerr << "query_error" << std::endl;
	exit(-1);
}

2、查

  1. 执行查询语句
  2. 得到结果集
  3. 得到结果集的行数和列数
  4. 遍历即可
cpp 复制代码
// 执行查找语句
std::string sql = "select * from  user;";
int ret4 = mysql_query(&mysql, sql.c_str());
if (ret4)
{
    std::cerr << "query_error" << std::endl;
    exit(-1);
}
// 得到结果集
MYSQL_RES* res = mysql_store_result(&mysql);

// 得到行数和列数
int row = mysql_num_rows(res);
int field = mysql_num_fields(res);

// 得到列名
MYSQL_FIELD* fields = mysql_fetch_fields(res);
for (int i = 0; i < row; i++)
{
    // 注意,不能直接打印,需要指定里面的name属性
    std::cout << fields[i].name << " ";
}
std::cout << "\n";

// 遍历得到结果集
MYSQL_ROW line;
for (int i = 0; i < row; i++)
{
    line = mysql_fetch_row(res);
    for (int j = 0; j < field; j++)
    {
        std::cout << line[j] << " ";
    }
    std::cout << "\n";
}

四、执行增删改查语句

cpp 复制代码
// 关闭数据库
mysql_close(&mysql);

cout << "\n";

}

复制代码
# 四、执行增删改查语句

[外链图片转存中...(img-9HkkinoN-1733452583128)]

```cpp
// 关闭数据库
mysql_close(&mysql);
相关推荐
q***31839 分钟前
Window下Redis的安装和部署详细图文教程(Redis的安装和可视化工具的使用)
数据库·redis·缓存
lingggggaaaa30 分钟前
免杀对抗——C2远控篇&PowerShell&有无文件落地&C#参数调用&绕AMSI&ETW&去混淆特征
c语言·开发语言·笔记·学习·安全·microsoft·c#
口袋物联31 分钟前
设计模式之建造者模式在 C 语言中的应用(含 Linux 内核实例)
c语言·设计模式·建造者模式
大锦终44 分钟前
【MySQL】基本查询
数据库·mysql
last_zhiyin1 小时前
Oracle sql tuning guide 翻译 Part 6-5 --- Hint使用报告的操作方法和例子
数据库·sql·oracle·sql tunning
Rysxt_1 小时前
Spring Boot SPI 教程
java·数据库·sql
切糕师学AI1 小时前
位带操作(Bit-Banding)是什么?
c语言·arm·嵌入式开发·cortex-m·位带操作
避避风港1 小时前
MySQL 从入门到实战
数据库·mysql
s***4531 小时前
MSSQL2022的一个错误:未在本地计算机上注册“Microsoft.ACE.OLEDB.16.0”提供程序
数据库·microsoft
学习路上_write1 小时前
嵌入式系统bringup指南:软硬件调试
c语言·单片机·嵌入式硬件