Ubuntu下使用C语言连接Mysql 8.0客户端教程
Ubuntu下如何C语言程序连接MYSQL 8.0(全教程)
1、 安装GCC(略)
2、 安装mysql(本人使用的是最新MySQL 8.0版本)
sudo apt install mysql-client
修改密码的教程请参考:https://blog.csdn.net/u013277209/article/details/108237466
(注意用ALTER 命令来改密码!)
(如果要允许远程访问,update user set host=’%’ where user=’root’)
3、 安装libmysqlclient-dev
sudo apt install libmysqlclient-dev
(这个会自动下载最新版本的连接库,不要加上任何数字!)
4、 如果上一步安装成功,你会在/usr/include/mysql中看到mysql.h,说明安装成功.
5、 直接include <mysql/mysql.h>即可引用
注意编译时:gcc -o mysqlTest $(mysql_config --cflags) mysqlTest.c $(mysql_config --libs)
一定要加上这几个config的参数,否则会编译失败
6、我的样例程序(有参考网络上的代码:Linux下使用C语言访问MySQL数据库(三):访问实现代码_麒麒川的博客-CSDN博客),经过测试可以正常打印数据库的内容
#include <mysql/mysql.h> //注意:apt install libmysqlclient-dev即可 #include <stdio.h> #include <stdlib.h> MYSQL *conn_ptr; MYSQL_RES *res_ptr; MYSQL_ROW sqlrow; unsigned int timeout = 7; //超时时间7秒 void dispaly_row(MYSQL *ptr) { unsigned int field_count = 0; while (field_count < mysql_field_count(ptr)) //返回在结果结合中字段的数目 { printf("%s", sqlrow[field_count]); field_count++; } printf("\n"); } void display_header() { MYSQL_FIELD *field_ptr; printf("Column details:\n"); while ((field_ptr = mysql_fetch_field(res_ptr)) != NULL) //返回列的定义字段信息 { printf("\t Name:%s\n", field_ptr->name); printf("\t Type:"); if (IS_NUM(field_ptr->type)) //若字段类型为数字 { printf("Numeric field\n"); } else { switch (field_ptr->type) { case FIELD_TYPE_VAR_STRING: printf("VACHAR\n"); break; case FIELD_TYPE_LONG: printf("LONG\n"); break; default: printf("Type is %d,check in mysql_com.h\n", field_ptr->type); } } printf("\t Max width %ld \n", field_ptr->length); if (field_ptr->flags & AUTO_INCREMENT_FLAG) printf("\t Auto increments\n"); printf("\n"); } } int main() { int ret = 0; int first_row = 1; conn_ptr = mysql_init(NULL); //初始化 if (!conn_ptr) { printf("mysql_init failed!\n"); return -1; } ret = mysql_options(conn_ptr, MYSQL_OPT_CONNECT_TIMEOUT, (const char *)&timeout); //设置超时选项 if (ret) { printf("Options Set ERRO!\n"); } conn_ptr = mysql_real_connect(conn_ptr, "localhost", "root", "这里写你数据库连接的密码", "testdb", 3306, NULL, 0); //连接MySQL testdb数据库,端口为3306 if (conn_ptr) { printf("Connection Succeed!\n"); ret = mysql_query(conn_ptr, "SELECT * FROM testTable"); //执行SQL语句 if (!ret) { res_ptr = mysql_use_result(conn_ptr); if (res_ptr) { display_header(); printf("Retrieved %lu rows\n", (unsigned long)mysql_num_rows(res_ptr)); //在结果集合中返回行的数量 while ((sqlrow = mysql_fetch_row(res_ptr))) //返回store_result中得到的结构体,并从中检索单行 { dispaly_row(conn_ptr);//打印表中的内容 } } if (mysql_errno(conn_ptr)) { printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息 return -2; } mysql_free_result(res_ptr); } else { printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息 return -3; } mysql_close(conn_ptr); printf("Connection closed!\n"); } else //错误处理 { printf("Connection Failed!\n"); if (mysql_errno(conn_ptr)) { printf("Connect Erro:%d %s\n", mysql_errno(conn_ptr), mysql_error(conn_ptr)); //返回错误代码、错误消息 } return -2; } return 0; }
7、Ubuntu下个人推荐使用Dbeaver来连接数据库,直接在商店中搜索Dbeaver下载即可。(DBeaver因为使用Java编写,所以在Windows和Mac上也有,是免费的数据库可视化软件中个人认为最好的)
注意默认的驱动仓库为maven主仓库,下载速度较慢,可以配置阿里云maven仓库(或者其他国内maven镜像都可以)来提高下载驱动的速度(记得移动到最顶上去)
本文来自博客园,作者:JessieLin,转载请注明原文链接:https://www.cnblogs.com/6543x1/p/15383192.html