圆月山庄资源网 Design By www.vgjia.com
Linux 下C语言连接mysql实例详解
第一步:
安装mysql, 参考:https://www.jb51.net/article/39190.htm
第二步:
安装mysql.h函数库
sudo apt-get install libmysqlclient-dev
执行之后就可以看到/usr/include/MySQL目录了
然后开始我们的链接.
首先看我的数据库
mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | chat_room | | mysql | | mysql_shiyan | | performance_schema | | sys | +--------------------+ 6 rows in set (0.00 sec) mysql> use chat_room; Reading table information for completion of table and column names You can turn off this feature to get a quicker startup with -A Database changed mysql> show tables; +---------------------+ | Tables_in_chat_room | +---------------------+ | user_message | +---------------------+ 1 row in set (0.00 sec) mysql> select * from user_message; +------+-------+--------+ | ID | name | passwd | +------+-------+--------+ | 1 | linux | linux | | 2 | lyt | lyt | +------+-------+--------+ 2 rows in set (0.00 sec)
可以看到,我在chat_room数据库中有user_message这张表,我们现在要做的就是读出这张表里的数据.
直接上代码
#include<stdio.h> #include<stdlib.h> #include<errno.h> #include<mysql/mysql.h> int main(void) { char *sql; sql="SELECT * FROM user_message;"; int res;//执行sql语句后的返回标志 MYSQL_RES *res_ptr;//指向查询结果的指针 MYSQL_FIELD *field;//字段结构指针 MYSQL_ROW result_row;//按行返回查询信息 int row,column;//查询返回的行数和列数 MYSQL *conn;//一个数据库链接指针 int i,j; //初始化连接句柄 conn = mysql_init(NULL); if(conn == NULL) { //如果返回NULL说明初始化失败 printf("mysql_init failed!\n"); return EXIT_FAILURE; } //进行实际连接 //参数 conn连接句柄,host mysql所在的主机或地址,user用户名,passwd密码,database_name数据库名,后面的都是默认 conn = mysql_real_connect(conn,"localhost","lyt","","chat_room",0,NULL,0); if (conn) { printf("Connection success!\n"); } else { printf("Connection failed!\n"); } mysql_query(conn,"set names gbk");//防止乱码。设置和数据库的编码一致就不会乱码 res = mysql_query(conn,sql);//正确返回0 if(res) { perror("my_query"); mysql_close(conn); exit(0); } else{ //把查询结果给res_ptr res_ptr = mysql_store_result(conn); //如果结果不为空,则输出 if(res_ptr) { column = mysql_num_fields(res_ptr); row = mysql_num_rows(res_ptr); printf("查到%d行\n",row); //输出结果的字段名 for(i = 0;field = mysql_fetch_field(res_ptr);i++) { printf("%10s",field->name); } puts(""); //按行输出结果 for(i = 1;i < row+1;i++){ result_row = mysql_fetch_row(res_ptr); for(j = 0;j< column;j++) { printf("%10s",result_row[j]); } puts(""); } } } //退出前关闭连接 mysql_close(conn); return 0; }
结果
gcc -o mysql a.c -L/usr/lib/mysql -lmysqlclient ./mysql Connection success! 查到2行 ID name passwd 1 linux linux 2 lyt lyt
注释写的相当清楚,有什么不清楚的可以给我留言,大家一块学习!
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
更新日志
2024年09月16日
2024年09月16日
- 人听人爱,入耳即溶《天碟落地3《HIFI瑰宝》示范颠峰之作》[WAV+CUE/分轨][839.9MB]
- 莫扎特安魂曲舍尔琴,维也纳国家歌剧院,1958【FLAC】
- 罗西尼五部歌剧序曲班贝格佩雷亚1958年【FLAC】
- 【HIRES】李云迪-莫扎特:钢琴奏鸣曲计划-萨尔兹堡-2024-24-96FLAC分轨
- 珍娜JheenaLodwick-GettingToKnowYou(XRCD)[WAV+CUE]
- 珍纳JheenaLodwick-AllMyLoving全我所爱(XRCD)[WAV+CUE]
- JheenaLodwick-Feeling挚爱(XRCD)[WAV+CUE]
- 人听人爱,入耳即溶《天碟落地2《测机王HQ》日本母带发烧音质》[WAV+CUE/分轨][709.9MB]
- 人听人爱,入耳即溶《天碟落地1《示范碟皇》殿堂级演绎名作》[WAV+CUE/分轨][786.9MB]
- MICO刘为《观·自在行》CD[FLAC/分轨][1.3GB]
- 珍纳JheenaLodwick-SingingInTheRain(XRCD)[WAV+CUE]
- 珍纳JheenaLodwick-Feelings非常感觉2-HDCD[WAV+CUE]
- 珍纳精选JheenaLodwick-JheenaLodwickGreatest[香港版]2015[WAV+CUE]
- 谁杀死了HI-FI音乐-《涂鸦精选VOL.2》[WAV+CUE]
- Mav-Mav《美芙的祈祷》(2000)[WAV+CUE]