当前位置: 首页 > news >正文

MySQL用C/C++连接

  • 连接库下载
  • mysql接口介绍
  • workbench

连接库下载

  1. 要想用C语言连接mysql,我们需要从mysql官网下载mysql提供的连接库

    选择C API

然后选择MySQL Connector/C++ 8.0

最后挑选自己的配置即可。

  1. 如果我们一开始使用yum源安装的话,他已经自动帮我们安装了连接库了,无需手动安装。

  2. 我们还可以用apt包直接下载:

sudoaptupdatesudoaptinstalllibmysqlclient-dev

最后我们可以检测是否存在mysql.h:

zhangwho@VM-0-2-ubuntu:~$find/usr -name"mysql.h"/usr/include/mysql/mysql.h

mysql接口介绍

我们可以用官网获取详细的接口介绍。

那么我们先介绍一些简单的接口:
首先要初始化:

mysql_init()


可以看到其返回MYSQL*:

然后就要连接:

MYSQL*mysql_real_connect(MYSQL*mysql,constchar*host,constchar*user,constchar*passwd,constchar*db,unsignedintport,constchar*unix_socunsignedlongclientflag);

为了便于测试,我们先创建用于连接的用户和数据库:

mysql>createdatabaseconn;Query OK,1rowaffected(0.02sec)mysql>useconn;Databasechanged mysql>createtabletest(->idintprimarykeyauto_increment,->namevarchar(20)notnull,->agetinyintdefault18->);Query OK,0rowsaffected(0.04sec)mysql>grantallonconn.*to'conn'@'localhost';Query OK,0rowsaffected(0.01sec)

连接数据库后通过mysql_query调用mysql:

intmysql_query(MYSQL*mysql,constchar*q);

我们先简单连接一下:

#include<iostream>#include<mysql/mysql.h>intmain(){MYSQL*mysql=mysql_init(nullptr);mysql=mysql_real_connect(mysql,"localhost","conn","123456","conn",3306,nullptr,0);if(mysql==nullptr)std::cerr<<"mysql connect errot\n";mysql_close(mysql);return0;}

当然这样不能有什么效果,我们故意将密码写错:

zhangwho@VM-0-2-ubuntu:~/Trainning/2026_1_29$ ./test mysql connect error

很好,接下里我们尝试插入数据:

#include<iostream>#include<mysql/mysql.h>intmain(){MYSQL*mysql=mysql_init(nullptr);mysql=mysql_real_connect(mysql,"localhost","conn","123456","conn",3306,nullptr,0);if(mysql==nullptr){std::cerr<<"mysql connect error\n";return1;}if(mysql_query(mysql,"insert into test(name) values('Alice')"))std::cerr<<"mysql query error\n";elsestd::cout<<"mysql query success\n";mysql_close(mysql);return0;}


没问题。
继续插入:

if(mysql_query(mysql,"insert into test(name) values('张三')"))


也没问题,说明我们的编码格式适配的很好。
那么我们尝试select:

if(mysql_query(mysql,"select * from test"))std::cerr<<"mysql query error\n";elsestd::cout<<"mysql query success\n";
zhangwho@VM-0-2-ubuntu:~/Trainning/2026_1_29$ ./test mysql query success

成功是成功了,但是没有什么结果啊!
我们还需要其他接口:

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 中的数据。

我们可以看到MYSQL_RES的结构:

此外,还能通过接口直接获取MYSQL_RES的数据:
获取结果行数mysql_num_rows

my_ulonglongmysql_num_rows(MYSQL_RES*res);

获取结果列数mysql_num_fields

unsignedintmysql_num_fields(MYSQL_RES*res);

获取列名mysql_fetch_fields

MYSQL_FIELD*mysql_fetch_fields(MYSQL_RES*res);

获取结果内容mysql_fetch_row

MYSQL_ROWmysql_fetch_row(MYSQL_RES*result);

最后释放MYSQL_RES

voidmysql_free_result(MYSQL_RES*result);

那么接下来我们就可以如此操作:

//获取列名for(inti=0;i<col;i++){std::cout<<filed[i].name<<'\t';}std::cout<<std::endl;//获取内容MYSQL_ROW line;for(inti=0;i<row;i++){line=mysql_fetch_row(res);for(intj=0;j<col;j++){std::cout<<line[j]<<'\t';}std::cout<<std::endl;}mysql_free_result(res);

输出:

zhangwho@VM-0-2-ubuntu:~/Trainning/2026_1_29$ ./test mysql query successidname age1Alice182张三18

没有问题

workbench

workbench是mysql官网提供的图形化界面

我们可以在win上下载workbench,当然同时要先下载mysql。

如果不想两个分开下载,我们可以下载MySQL Installer

选择下面的安装包,然后:

选择Full即可。
在等待下载的这段时间,我们可以将conn的登录主机改为%:

mysql>updateusersetHost='%'whereuser='conn';Query OK,1rowaffected(0.01sec)Rowsmatched:1Changed:1Warnings:0mysql>selecthost,user,authentication_stringfromuser;+-----------+------------------+------------------------------------------------------------------------+|host|user|authentication_string|+-----------+------------------+------------------------------------------------------------------------+|%|conn|$A$005$o`unF%\r~f~%53Hmgs258v3VDpbsTfYTu4gyTbyCDhGIsJpwUgjKM.k6B8||localhost|mysql.infoschema|$A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED||localhost|mysql.session|$A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED||localhost|mysql.sys|$A$005$THISISACOMBINATIONOFINVALIDSALTANDPASSWORDTHATMUSTNEVERBRBEUSED||localhost|root|$A$005$c3OCZ*k@w6s4#r)oD1TOBStybtxtwaEeZ1KfZ9mbVFiR4LD3x/1vxhtrnD |+-----------+------------------+------------------------------------------------------------------------+5rowsinset(0.00sec)

当然这样修改是不足的,还需要对一些权限进行修改。最好就是删除了重新创建用户。
随后我们使用这个账户继续进行测试.

选择+,添加新的连接:


如此我们就能对数据库进行操作:

我们能直接在图形界面写入数据,然后点击右下角的apply

他就会自动写入相应的sql语句。
总之就是这样!

http://www.jsqmd.com/news/320162/

相关文章:

  • 2026年诚信的大连校企合作的公司行业推荐TOP榜
  • 不想用 ElevenLabs?2026 年 7 款 AI 语音、TTS 与语音克隆替代方案评测
  • 2026年诚信的大连学习3D建模质量榜
  • 2026国自然改版“瘦身”,科研人破局全靠这款AI神器!
  • DeepBI Listing 优化功能第二弹:保姆级优化报告,对着抄就赢!
  • 2026年专业的大连日本留学签证/大连日本留学品牌力榜
  • 2026年质量好的自动吨袋包装机/称重式吨袋包装机厂家最新推荐排行榜
  • 2026年可靠的大连日本语言学校申请奖金/大连日本语言学校申请签证服务力排名
  • 夷陵区农资选购全攻略:2026年优质店铺推荐与避坑指南
  • 2026年热门的铝箔全身式隔热服/炉前隔热服值得信赖厂家推荐(精选)
  • 2026年湖北彩色玻璃实力供应商综合评选指南
  • 2026年口碑好的纺织硅油/化妆品保湿剂硅油厂家推荐及选择参考
  • 武汉方矩管销售公司哪家信誉好?2026年精选6家实力厂商
  • 2026年太原岩土勘察实力机构深度测评与优选指南
  • 2026年湖北别墅石材装饰品牌选购全攻略与TOP服务商解析
  • 2026年第一季度武汉镀锌管优质供应商综合评测与推荐
  • 2026年1月合肥京东代运营服务商综合评估与精选推荐
  • 2026年湖北建筑色玻采购指南:如何联系靠谱供应商
  • 本科毕业论文真的不用太发愁
  • 表格、公式、印章识别太难?OpenVINO™ Day 0 支持 PaddleOCR-VL-1.5:端侧文档解析一键 SOTA
  • 2026年靠谱的高端杭州网站/杭州网站开发品牌实力榜
  • 2026年靠谱的大连高端搬家公司/大连工厂搬家公司服务专业度榜
  • 周口大平层设计指南:2026年设计师选择与经典案例解析
  • 2026年山东聚丙烯网状纤维优质厂家盘点与选购指南
  • 2026年热门的专业水溶肥/正规水溶肥最新TOP厂家排名
  • 2026年靠谱的盲板不锈钢法兰/承插焊不锈钢法兰厂家最新热销排行
  • 2026年宜昌夷陵区农作物种子代理商综合选购指南
  • 2026河北热蒸发镀膜机实力公司综合评测与选型指南
  • 2026年比较好的搬运公司/大连搬运公司行业实力榜
  • 2026年热门的北京继承律师事务所/北京继承律师值得信赖榜