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镜像都可以)来提高下载驱动的速度(记得移动到最顶上去)
Ubuntu下使用C语言连接Mysql 8.0客户端教程的更多相关文章
- Windows下用C语言连接Mysql注意问题
原文:Windows下用C语言连接Mysql注意问题 环境是:在VS6.0 安装Mysql后,我们需要相应的头文件以及lib文件,所以安装过程必须是完整安装.否则不会生成include文件夹哦~ 具体 ...
- Linux centos 7/ubantu下: 用 C 语言连接 MySQL数据库
前言:最近用IPC.socket做ATM.聊天项目,考虑到需要用到数据库,所以总结一下centos.ubantu环境下怎么用C语言操作数据库,例如常见的增删改查等! 一.Centos环境安装mysql ...
- Linux下C语言连接MySQL
本文出自 http://blog.csdn.net/shuangde800 首先保证安装: 1:安装MySQL:sudo apt-get install mysql-server mysql-cl ...
- c语言连接mysql数据库的实现方法
C语言连接mysql数据库,需要相应的头文件和lib文件,如果你安装Mysql数据库,会在安装目录下找到这些库文件,如果没有安装,也可以在网上找到 我这里也有一份网上找到的:/201205/other ...
- R语言-连接MySQL数据库方法
版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] R语言连接数据库常用的方法有2种: 1.使用R数据库接口 连接MySQL,使用RMySQL包,使用前RMySQL包要先安 ...
- C语言连接mysql -insert-update
C语言连接mysql数据库实现insert语句:数据库:test表:systeminfo CREATE TABLE `systeminfo` ( `id` int(11) NOT NULL AUTO ...
- Linux系统下 解决Qt5无法连接MySQL数据库的方法
Linux平台下解决Qt5连接mysql数据库的问题:输入sudo apt-get install libqt5sql5-mysql解决,这种方法只能解决Qt是用sudo apt-get instal ...
- C语言连接MySql数据库
C语言连接MySql数据库(CodeBlocks) 操作系统:Windows7(32位)编译软件:Code::Blocks 10.05数 据 库:mysql-5.1.62-win32 数据库内的数据: ...
- 在VS下用C语言连接SQLServer2008
原文:在VS下用C语言连接SQLServer2008 step1:启动SQLSERVER服务 step2:打建立数据库test,在test库中建立test表(a varchar(200),b varc ...
随机推荐
- interface中setup_time和hold_time
interface中的setup_time和hold_time input:约束input信号提前T时间采样,然后在时钟沿更新到input信号上. output:约束output信号,在时钟沿T时间后 ...
- Dubbo源码剖析六之SPI扩展点的实现之Adaptive功能实现原理
接Dubbo源码剖析六之SPI扩展点的实现之getExtensionLoader - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)继续分析Adaptive功能实现原理.Adaptive的主 ...
- Dubbo服务注册到Zookeeper,对外提供服务的实际类 ref(如:SleepServiceImpl)保存在哪里
Dubbo服务注册到Zookeeper,其注册的内容为实际对外提供的服务的实现.这个实现保存在哪里(至于具体客户端使用时怎么取后后续阐述)?可以看看Dubbo如何处理的. 对于@DubboServic ...
- libc++abi.dylib: terminating with uncaught exception of type NSException
这是微信sdk注册时候报的错误 解决方法 选择Build Setting,在"Other Linker Flags"中加入"-Objc -all_load"
- 学着去看开 你不是一个low程序员
http://www.cocoachina.com/programmer/20160627/16835.html 看完这篇文章 感谢作者
- 巧用 CSS 把图片马赛克化
一.image-rendering 介绍 CSS 中有一个有趣的特性叫 image-rendering,它可以通过算法来更好地显示被缩放的图片. 假设我们有一张尺寸较小的二维码截图(下方左),将其放大 ...
- 录毛线脚本,直接手写接口最简洁的LoadRunner性能测试脚本(含jmeter脚本)
近日翻看了下招聘信息,很多都要求loadrunner和jmeter这两款工具,毕竟是性能测试的主流客户端并发工具. 录制的问题 做性能脚本是性能测试的基本功,loadrunner和jmeter这两款工 ...
- PentestBox在win10里打不开工具 显示无系统命令的解决方法
PentestBox详细安装过程:http://www.cnblogs.com/ESHLkangi/p/8336398.html 在使用PentestBox的时候出现了打不开工具的问题,最后看到一个大 ...
- yalmip安装
1,将yalmip解压,在matlab中添加路径. 2,yalmiptest测试是否安装成功.
- html 多种空格转义字符
记录一下,空格的转义字符分为如下几种: 1. &160#;不断行的空白(1个字符宽度) 2. &8194#;半个空白(1个字符宽度) 3. &8195#;一个空白(2个 ...