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);
相关推荐
码农小站4 分钟前
ClickHouse 时间范围查询:精准筛选「本月数据」
数据库
黎明smaly19 分钟前
【排序】插入排序
c语言·开发语言·数据结构·c++·算法·排序算法
paopaokaka_luck31 分钟前
基于SpringBoot+Vue的非遗文化传承管理系统(websocket即时通讯、协同过滤算法、支付宝沙盒支付、可分享链接、功能量非常大)
java·数据库·vue.js·spring boot·后端·spring·小程序
小疯仔1 小时前
navicat导出数据库的表结构
数据库
TOSUN同星1 小时前
干货分享 | TSMaster DBC编辑器操作指南:功能详解+实战示例
数据库·oracle·编辑器·汽车·软件工程
LIN-JUN-WEI2 小时前
[ESP32]VSCODE+ESP-IDF环境搭建及blink例程尝试(win10 win11均配置成功)
c语言·开发语言·ide·vscode·单片机·学习·编辑器
huihui4502 小时前
一天一道Sql题(day01)
数据库
~尼卡~2 小时前
软考(软件设计师)数据库原理:事务管理,备份恢复,并发控制
数据库·软件设计师-软考
八九燕来2 小时前
Django双下划线查询
数据库·django·sqlite
眠りたいです3 小时前
Mysql常用内置函数,复合查询及内外连接
linux·数据库·c++·mysql