「MySQL-04」Linux环境下使用C/C++连接并操纵MySQL

news2025/1/15 13:57:33

目录

一、准备mysql库:Connector/C

1. 查看是否有mysql相关的库和头文件

2. 安装devel(开发库)

3.到官网下载开发包,并上传到Linux

3.0 须知

3.1 到官网下载开发包

3.2 上传安装包至Linux

二、mysql库:Connector/C 的使用

1. 创建并初始化mysql对象

2. 销毁mysql对象

3. 链接数据库

4. 设置编码格式

5. 下发SQL语句给数据库

6. 获取执行sql语句的结果

6.1 从myql对象里读取结果

6.2 从MYSQL_RES对象里获取行数

6.3 从MYSQL_RES对象里获取列数

6.4 从MYSQL_RES对象里获取列名

6.5 从MYSQL_RES对象里一行一行的读取结果

拓展】Connector/C库还支持事务等常用操作 

练习】使用Connector/C库编写一个简易的mysql客户端


一、准备mysql库:Connector/C

        要使用C/C++连接mysql,需要devel(开发库),一般来说在Linux上下好了MySQL这个库也会顺带给我们下载好。如果没有也可以单独安装。

1. 查看是否有mysql相关的库和头文件

  • 使用命令 rpm -qa | grep mysql 查看是否有mysql相关的库,重点是devel(开发库):

        

  • 使用命令 ls /lib64/mysql/ -al 查看库的链接情况

        

  • 使用命令 ls /usr/include/mysql/ 查看mysql相关的头文件:

        

2. 安装devel(开发库)

如果只是缺少devel(开发库)可尝试用yum安装

yum install -y mysql-community-devel

安装好devel(开发库)后:

我们只需要用 #include <mysql/mysql.h>  就可引入mysql库。

编译时加上:-L/lib64/mysql -lmysqlclient 帮助编译器找到头文件和库即可。

3.到官网下载开发包,并上传到Linux

3.0 须知

        如果无法安装devel(开发库),还可以到官网下载开发包,再上传到Linux,但是不推荐怎么做,因为可能会因为开发包和自己MySQL的版本不同而出现各种奇奇怪怪的问题:如ssl证书问题,套接字问题……

        所以能不这样做尽量不要这样做,要用这个方法还不如看博主文章重新安装MySQL。

按照里面的方法一定能安装好mysql和devel(开发库)。


3.1 到官网下载开发包

a. 官网下载Download Archives

 b. 选择MySQL Connector/C

c. 选择系统和版本。下图为Linux版的下载。


3.2 上传安装包至Linux

a. 上传安装包: rz -y

b. 解压: tar -xzvf mysql-connector-c-6.1.11-linux-glibc2.12-x86_64.tar.gz

c. 在要使用库的目录下建立头文件的软链接和库的软链接

d. 修改配置文件让g++编译时能找到动态库

如果提示找不到动态库libmysqlclient,我们还需要修改配置文件(以下命令建议在root用户下执行):

1. 添加配置文件:vim /etc/ld.so.conf.d/lib_search.conf

2. 往里面加入 mysql库中lib目录的路径:

        路径获取方式:cd进入刚才解压好的文件中,使用pwd lib查看lib目录的路径

3. 然后运行指令 sudo ldconfig 更新配置文件

e. 写代码时要引入头文件 "软链接地址/mysql.h"

编译时要加上 -I./头文件的软链接地址/include -L./库的软链接地址 -lmysqlclient 帮助编译器找到头文件和库。


二、mysql库:Connector/C 的使用

1. 创建并初始化mysql对象

函数:
    mysql_init()
示例:
    MYSQL *mysql = mysql_init(NULL);

2. 销毁mysql对象

函数:
    mysql_close(要销毁的对象);
示例:
    mysql_close(mysql);

3. 链接数据库

初始化完毕之后,必须先链接数据库,在进行后续操作。(mysql网络部分是基于TCP/IP的)

函数:
    mysql_real_connect(mysql, host, user, passwd, db, port, unix_socket, clientflag)
    //使用指定用户登录指定数据库,该用户必须有远程访问权限

参数说明:
    mysql  :  mysql对象
    host   :  要连接的主机
    user   :  mysql用户,该用户必须有远程访问权限
    passwd :  用户密码
    db     :  要连接的数据库
    port   :  端口号
    unix_socket :  套接字,nullptr为默认由系统选择
    clientflag  :  客户端标志,默认为0

示例:
{
    std::string host   = "localhost";
    std::string user   = "test"; //该用户必须有远程访问权限
    std::string passwd = "123";
    std::string db     = "test_table";
    unsigned int port   = 3306;
    if(mysql_real_connect(mysql, host.c_str(), user.c_str(), passwd.c_str(), db.c_str(), port, nullptr, 0) == nullptr)
    {
        fprintf(stderr, "%s\n", mysql_error(mysql)); //显示连接时遇到的错误
        std::cerr << "Failed to connect to MySQL user!\n";
        exit(-2);
    }
    std::cout << "Successfully to connect to MySQL user!\n";
}

4. 设置编码格式

//建立好链接之后,获取英文没有问题,但如果获取中文就是乱码。
//设置链接的默认字符集为utf8,原始默认是latin1(拉丁文)
mysql_set_character_set(myfd, "utf8");

5. 下发SQL语句给数据库

函数:
    int mysql_query(MYSQL *mysql, const char *sql);
    //下发SQL语句,让上面指定用户执行SQL语句对上面指定的数据库进行操作
参数:
    mysql : mysql对象
      sql : sql语句
返回值:
    成功返回0,失败返回1。
示例:
    std::string sql = "select * from test_table";
    int n = mysql_query(mysql, sql.c_str());

6. 获取执行sql语句的结果

sql执行完以后,如果是查询语句,我们还要读取查询出来的结果,该结果以二进制的形式被保存在mysql对象里,所以我们还需要一个函数来读取保存在mysql对象里的结果。

6.1 从myql对象里读取结果

函数:
    MYSQL_RES *mysql_store_result(MYSQL *mysql);

参数:
    mysql对象。

返回值:
    MYSQL_RES对象,一个专门用来保存查询结果的对象,它有各种获取结果的方法。

说明:
    对于该函数,我们需要自己创建一个MYSQL_RES指针来接收返回的MYSQL_RES对象,因为
MYSQL_RES对象malloc了一片内存空间来存储查询过来的数据,所以我们一定要记得 free(),
不然会造成内存泄漏。如果用的是较新版本的devel(开发库),可能创建出来的MYSQL_RES对象
会自动释放,free会报空指针异常,就不用free。执行完mysql_store_result()以后,其实
数据都已经在MYSQL_RES对象中了,下面的api基本就是读取 MYSQL_RES对象中的数据。

示例:
    MYSQL_RES* res = mysql_store_result(mysql);
    if(res == nullptr) exit(0);
    free(res); //如果报错证明当前版本的开发库中的mysql对象会自动释放,删除此句即可。

6.2 从MYSQL_RES对象里获取行数

函数:
    my_ulonglong mysql_num_rows(MYSQL_RES *res);

参数:
    MYSQL_RES对象。

返回值:
    一个长整型。

示例:
    int rows = mysql_num_rows(res);
    std::cout << "表中有" << rows << "行。\n";

6.3 从MYSQL_RES对象里获取列数

函数:
    unsigned int mysql_num_fields(MYSQL_RES *res);
参数:
    MYSQL_RES对象。
返回值:
    一个无符号整型。
示例:
    int cols = mysql_num_fields(res);
    std::cout << "表中有" << cols << "列。\n";

6.4 从MYSQL_RES对象里获取列名

函数:
    MYSQL_FIELD *mysql_fetch_fields(MYSQL_RES *res);

参数:
    MYSQL_RES对象。

返回值:
    MYSQL_FIELD:结构体数组指针,指向结构体数组,结构体的name成员为字符串通过用来保存列名。

示例:
    int cols = mysql_num_fields(res); //获取列数
    MYSQL_FIELD *col_name = mysql_fetch_fields(res);
    for(int i = 0; i < cols; i++)
    {
        std::cout << col_name[i].name << "  |  ";
    }

6.5 从MYSQL_RES对象里一行一行的读取结果

函数:
    MYSQL_ROW mysql_fetch_row(MYSQL_RES *result);

参数:
    MYSQL_RES对象。

返回值:
    MYSQL_ROW对象,相当于一个二维数组,用来保存表中内容

示例:
    MYSQL_ROW line; //创建MYSQL_ROW对象,用来保存表中内容
    for(int i = 0; i < rows; i++) //行数rows通过mysql_num_rows()获取。
    {
        line = mysql_fetch_row(res);
            
        for(int j = 0; j < cols; j++) //列数cols通过mysql_num_fields()获取。
        {
            std::cout << line[j]<< " "; //打印第i行的第j列内容。
        }
        std::cout << std::endl;
    }


拓展】Connector/C库还支持事务等常用操作 

my_bool STDCALL mysql_autocommit(MYSQL * mysql, my_bool auto_mode);
my_bool STDCALL mysql_commit(MYSQL * mysql);
my_bool STDCALL mysql_rollback(MYSQL * mysql);

练习】使用Connector/C库编写一个简易的mysql客户端

源代码:MySQL · yblhlk/Linux课程 - 码云 - 开源中国 (gitee.com)


------------------------END-------------------------

才疏学浅,谬误难免,欢迎各位批评指正。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/955285.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

DataLoader的使用

示例代码&#xff1a; import torchvision from torch.utils.data import DataLoader from torch.utils.tensorboard import SummaryWriter# 准备的测试数据集 test_data torchvision.datasets.CIFAR10("./dataset", trainFalse, transformtorchvision.transforms.…

react里map嵌套

1、tab是我自己声明的变量&#xff0c;item是下标&#xff0c;index是key值&#xff08;这些都可以改为自己的数据&#xff09; tab是声明的所有数据&#xff0c;而list是所有数据里面所需要的那一个&#xff0c;items和indexs可以虽然写一个名称代替

HTML基础--Form表单--内联元素

目录 Form表单 表单元素 创建表单 () 文本输入 () 密码输入 单选按钮 () 和 复选框 () 下拉列表 () 和 选项 ()提交按钮 () 重置按钮 () 块元素与行内元素&#xff08;内联元素&#xff09; Form表单 HTML中的表单&#xff08;<form>&#xff09;是一个重要的元…

WPF C# .NET7 基础学习

学习视频地址&#xff1a;https://www.bilibili.com/video/BV1hx4y1G7C6?p3&vd_source986db470823ebc16fe0b3d235addf050 开发工具&#xff1a;Visual Studio 2022 Community 基础框架&#xff1a;.Net 6.0 下载创建过程略 .Net和.Framework 区别是Net是依赖项&#xff…

EasyAVFilter的初衷:把ffmpeg.c当做SDK来用,而不是当做EXE来用

之前我们做一个视频点播的功能&#xff0c;大概的流程就是将上传上来的各种格式的视频&#xff0c;用FFmpeg统一进行一次转码&#xff0c;如果probe到视频的编码格式是H.264就调用-vcodec copy&#xff0c;如果probe到视频的编码格式不是H.264就调用-vcodec libx264&#xff0c…

SpringBoot中自定义starter

SpringBoot自动装配原理&#xff1a; EnableAutoConfiguration注解开启自动装配功能&#xff0c;该注解通常放在应用的主类上。spring.factories文件位于META-INF目录下的配置文件中定义各个自动装配类的全限定名 当SpringBoot启动时&#xff0c;会加载classpath下所有的spri…

JavaScript 手写题

基础手写 全排列&#xff08;力扣原题&#xff09; 要求以数组的形式返回字符串参数的所有排列组合。 注意&#xff1a; 字符串参数中的字符无重复且仅包含小写字母返回的排列组合数组不区分顺序const _permute string > {const result []const map new Map()const df…

vue使用打印组件print-js

项目场景&#xff1a; 由于甲方要求&#xff0c;项目需要打印二维码标签&#xff0c;故开发此功能 开发流程 安装包&#xff1a;npm install print-js --saveprint-js的使用 <template><div id"print" ref"print" ><p>打印内容<p&…

可拖拽编辑的流程图X6

先上图 //index.html&#xff0c;有时候可能加载失败&#xff0c;那就再找一个别的cdn 或者npm下载&#xff0c;如果npm下载&#xff0c; //那么需要全局引入或者局部引入&#xff0c;代码里面写法也会不同&#xff0c;详细的可以看示例<script src"https://cdn.jsdeli…

python可视化——pycharm——Grid - Grid_overlap_multi_xy_axis图

这段代码使用了pyecharts库来创建一个Grid-Overlap图&#xff0c;包括柱状图和折线图。 首先&#xff0c;创建了一个柱状图对象bar&#xff0c;并添加了两个y轴的数据。第一个y轴代表csdn博客数量&#xff0c;第二个y轴代表粉丝数量。然后&#xff0c;使用extend_axis方法扩展…

6、深入解析Kotlin类与对象:构造、伴生、单例全面剖析

前言 本篇文章将带您了解Kotlin编程中的重要概念&#xff1a;类及构造函数、访问修饰符、伴生对象和单例模式。就像搭积木一样&#xff0c;我们会逐步揭开这些概念的面纱&#xff0c;让您轻松理解它们的作用和用法。无论您是编程新手还是有经验的开发者&#xff0c;本文都将为…

一个独立的测试人如何完成一个项目的测试 + 发布

其实啊&#xff0c;每个人都可以「独立完成一个项目的测试 发布」 很多同学&#xff0c;工作了五六年&#xff0c;都没有机会&#xff08;也许是&#xff1a;不敢&#xff09;独立负责一个完整项目的测试&#xff08;独立负责一个项目测试后的上线流程&#xff0c;机会就更少…

手把手教你调用5个公共API获取数字货币市场数据(内附详细源码)

数量技术宅团队在CSDN学院推出了量化投资系列课程 欢迎有兴趣系统学习量化投资的同学&#xff0c;点击下方链接报名&#xff1a; 量化投资速成营&#xff08;入门课程&#xff09; Python股票量化投资 Python期货量化投资 Python数字货币量化投资 C语言CTP期货交易系统开…

three.js(十):线性几何体

线性几何体 WireframeGeometry 网格几何体EdgesGeometry 边缘几何体 WireframeGeometry 网格几何体 WireframeGeometry( geometry : BufferGeometry ) geometry — 任意几何体对象。 const geometry new SphereGeometry(); const wireframe new WireframeGeometry(geometr…

2022年06月 C/C++(五级)真题解析#中国电子学会#全国青少年软件编程等级考试

第1题&#xff1a;逃离迷宫 你在一个地下迷宫中找到了宝藏&#xff0c;但是也触发了迷宫机关&#xff0c;导致迷宫将在T分钟后坍塌&#xff0c;为此你需要在T分钟内逃离迷宫&#xff0c;你想知道你能不能逃离迷宫。迷宫是一个边长为m的正方形&#xff0c;其中"S"表示…

完善会计流程的关键功能:了解必备的会计软件功能!

会计软件已经成为许多大小企业的财务管理标配。会计软件可以帮助企业自动化财务流程&#xff0c;提高工作效率&#xff0c;减少错误&#xff0c;并提供准确和可靠的财务数据。一款合格的会计软件应该具备什么功能呢&#xff1f; 会计软件应有的功能 1、账户管理&#xff1a;会…

overlayfs

参考&#xff1a;How containers work: overlayfs how overlays work Overlay filesystems, also known as “union filesystems” or “union mounts” let you mount a filesystem using 2 directories: a “lower” directory, and an “upper” directory. Basically: t…

C语言之练习题

欢迎来到我的&#xff1a;世界 希望作者的文章对你有所帮助&#xff0c;有不足的地方还请指正&#xff0c;大家一起学习交流 ! 目录 前言填空题&#xff1a;第一题第二题第三题第四题 编程题&#xff1a;第一题&#xff1a;第二题&#xff1a; 总结 前言 填空题&#xff1a; …