[MySQL][访问 -- 使用C API连接]详细讲解
2025/7/25 22:00:57
来源:https://blog.csdn.net/qq_37281656/article/details/140630407
浏览:
次
关键词:[MySQL][访问 -- 使用C API连接]详细讲解
目录
- 0.如何下载库?
- 1.Connector/C 使用
- 2.MYSQL接口介绍
- 0.MYSQL结构体
- 1.初始化 -- mysql_init()
- 2.链接数据库 -- mysql_real_connect()
- 3.下发MYSQL命令 -- mysql_query()
- 4.获取执行结果 -- mysql_store_result()
- 5.获取结果行数 -- mysql_num_rows()
- 6.获取结果列数 -- mysql_num_fields
- 7.获取列名mysql_fetch_fields
- 8.获取结果内容 -- mysql_fetch_row
- 9.关闭MYSQL链接 -- mysql_close()
- 10.补充
- 3.图形化界面推荐
0.如何下载库?
- 要使用C语言连接MYSQL,需要使用MYSQL官网提供的库,可以去官网下载
- 也可以通过yum(Centos)或者apt(Ubuntu)直接安装mysql-devel
1.Connector/C 使用
2.MYSQL接口介绍
0.MYSQL结构体
- C API中一个非常重要的变量(mysql_init的返回值)
- 里面内存非常丰富,有 port,dbname,charset等连接基本参数
- 它也包含了一个叫st_mysql_methods的结构体变量,该变量里面保存着很多函数指针,这些函数指针将会在数据库连接成功以后的各种数据操作中被调用
1.初始化 – mysql_init()
- 要使用库,必须先进行初始化!
- 函数原型:
MYSQL *mysql_init(MYSQL *mysql);
- 示例:
MYSQL *my = mysql_init(NULL)
2.链接数据库 – mysql_real_connect()
- 初始化完毕之后,必须先链接数据库,再进行后续操作(mysql网络部分是基于TCP/IP的)
- 函数原型:
MYSQL *mysql_real_connect(MYSQL * mysql, const char *host,const char *user,const char *passwd,const char *db,unsigned int port,const char *unix_socket,unsigned long clientflag);
- 建立好链接之后,获取英文没有问题,如果获取中文是乱码
- 设置链接的默认字符集是utf8,原始默认是latin1
- mysql_set_character_set(myfd, “utf8”);
3.下发MYSQL命令 – mysql_query()
- 函数原型:
int mysql_query(MYSQL *mysql, const char *q);
- 参数
q
:要执行的sql语句,如"select * from table
"
4.获取执行结果 – mysql_store_result()
- SQL执行完以后
- 如果是update,insert等语句,那么就看下操作成功与否即可
- 如果是查询语句,当然还要读取数据
- 如果mysql_query返回成功,那么就通过mysql_store_result这个函数来读取结果
- 函数原型:
MYSQL_RES *mysql_store_result(MYSQL *mysql);
- 功能:
- 该函数会调用MYSQL变量中的st_mysql_methods中的 read_rows 函数指针来获取查询的结果
- 同时该函数会返回 MYSQL_RES 这样一个变量
- 该变量主要用于保存查询的结果
- 同时该函数malloc了一片内存空间来存储查询过来的数据
- 所以一定要记得free(result),不然是肯定会造成内存泄漏的
- 执行完mysql_store_result以后,其实数据都已经在 MYSQL_RES 变量中了,下面的api基本就是读取 MYSQL_RES 中的数据
5.获取结果行数 – mysql_num_rows()
- 函数原型:
my_ulonglong mysql_num_rows(MYSQL_RES *res);
6.获取结果列数 – mysql_num_fields
- 函数原型:
unsigned int mysql_num_fields(MYSQL_RES *res);
7.获取列名mysql_fetch_fields
8.获取结果内容 – mysql_fetch_row
9.关闭MYSQL链接 – mysql_close()
- 函数原型:
void mysql_close(MYSQL *sock);
10.补充
3.图形化界面推荐
- Navicat
- SQLyog
- MYSQL Workbench
版权声明:
本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。
我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com