「MySQL-04」Linux环境下使用C/C++连接并操纵MySQL
目录
一、准备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语句的结果
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-------------------------
才疏学浅,谬误难免,欢迎各位批评指正。
相关文章:

「MySQL-04」Linux环境下使用C/C++连接并操纵MySQL
目录 一、准备mysql库:Connector/C 1. 查看是否有mysql相关的库和头文件 2. 安装devel(开发库) 3.到官网下载开发包,并上传到Linux 3.0 须知 3.1 到官网下载开发包 3.2 上传安装包至Linux 二、mysql库:Connector/C 的使用 1. 创建并初始化mys…...
【力扣】两数相除(c/c++)
目录 题目 注意: 示例 1: 示例 2: 提示: 题目解析 题目思路 代码思路 数据处理 注意 减法函数 第一次使用的函数 问题 第二次改良后的代码 处理i的值并且返回 总代码 力扣的代码 注意 题目 给你两个整数,被除数 dividend 和…...

《Kubernetes部署篇:Ubuntu20.04基于二进制安装安装kubeadm、kubelet和kubectl》
一、背景 由于客户网络处于专网环境下, 使用kubeadm工具安装K8S集群,由于无法连通互联网,所有无法使用apt工具安装kubeadm、kubelet、kubectl,当然你也可以使用apt-get工具在一台能够连通互联网环境的服务器上下载kubeadm、kubele…...

go学习part21 Redis
300_尚硅谷_Redis的基本介绍和原理示意_哔哩哔哩_bilibili Redis 命令 | 菜鸟教程 (runoob.com) 1.基本介绍 2.基本操作 Redis的基本使用: 说明:Redis安装好后,默认有16个数据库,初始默认使用0号库,编号是0...15 1.添加key-val [set] 2.查看当前redi…...

时序预测 | MATLAB实现基于PSO-BiGRU、BiGRU时间序列预测对比
时序预测 | MATLAB实现基于PSO-BiGRU、BiGRU时间序列预测对比 目录 时序预测 | MATLAB实现基于PSO-BiGRU、BiGRU时间序列预测对比效果一览基本描述程序设计参考资料 效果一览 基本描述 1.时序预测 | MATLAB实现基于PSO-BiGRU、BiGRU时间序列预测; 2.单变量时间序列数…...

Unity3D下如何采集camera场景数据并推送RTMP服务?
Unity3D使用场景 Unity3D是非常流行的游戏开发引擎,可以创建各种类型的3D和2D游戏或其他互动应用程序。常见使用场景如下: 游戏开发:Unity3D是一个广泛用于游戏开发的环境,适用于创建各种类型的游戏,包括动作游戏、角…...

黑客可利用 Windows 容器隔离框架绕过端点安全系统
新的研究结果表明,攻击者可以利用一种隐匿的恶意软件检测规避技术,并通过操纵 Windows 容器隔离框架来绕过端点安全的解决方案。 Deep Instinct安全研究员丹尼尔-阿维诺姆(Daniel Avinoam)在本月初举行的DEF CON安全大会上公布了…...
STM32注入通道
什么是注入通道? 注入通道是ADC的一种采样方式,主要用于在规则通道转换期间并行处理快速变化信号的采样。注入通道的转换可以在规则通道转换时强行插入,相当于一个“中断通道”。当有注入通道需要转换时,规则通道的转换会停止,优先执行注入通道的转换,当注入通道的转换执…...

WebVR — 网络虚拟现实
推荐:使用 NSDT编辑器 快速搭建3D应用场景 虚拟现实设备 随着Oculus Rift和许多其他生产设备即将上市,未来看起来很光明——我们已经有足够的技术来使VR体验“足够好”,可以玩游戏。有许多设备可供选择:像Oculus Rift或HTC Vive这…...
ASP.NET Core 的 Routing
ASP.NET Core 的 Routing ASP.NET Core 的 controllers 使用Routing 中间件匹配客户端的 url 请求,然后映射到对应的 controller 的处理方法(Action)上。 Actions 可以是 常规路由 或 属性路由 的映射。 MVC App一般使用常规路由。 REST API…...

IBM Spectrum LSF Explorer 为要求苛刻的分布式和任务关键型高性能技术计算环境提供强大的工作负载管理
IBM Spectrum LSF Explorer 适用于 IBM Spectrum LSF 集群的强大、轻量级报告解决方案 亮点 ● 允许不同的业务和技术用户使用单一解决方案快速创建和查看报表和仪表板 ● 利用可扩展的库提供预构建的报告 ● 自定义并生成性能、工作负载和资源使用情况的报…...

RHCE——十一、NFS服务器
NFS服务器 一、简介1、NFS背景介绍2、生产应用场景 二、NFS工作原理1、示例图2、流程 三、NFS的使用1、安装2、配置文件3、主配置文件分析3.1 实验1 4、NFS账户映射4.1 实验24.2 实验3 四、autofs自动挂载服务1、产生原因2、安装3、配置文件分析4、实验45、实验5 一、简介 1、…...
Python编程练习与解答 练习100:随机密码
编写一个生成最忌密码的函数,密码的长度应该在7-10个字符之间。每个字符应该从ASCII表的第33位到126位中随机选择。函数不接受任何参数,返回随机生成的密码作为位移结果。在文件的main程序中显示随机生成的密码。main程序只在解答没有被导入另一个文件时…...

华为云云服务器评测 | 从零开始:云耀云服务器L实例的全面使用解析指南
文章目录 一、前言二、云耀云服务器L实例要点介绍2.1 什么是云耀云服务器L实例2.1.1 浅析云耀云服务器L实例 2.2 云耀云服务器L实例的产品定位2.3 云耀云服务器L实例优势2.4 云耀云服务器L实例支持的镜像与应用场景2.5 云耀云服务器L实例与弹性云服务器(ECS…...

欧科云链研究院探析Facebook稳定币发行经历会不会在PayPal重演
引言 作者最近的报告-探析PayPal发行稳定币是否会重蹈Facebook覆辙-近期被英国的金融时报(中文版)刊登。由于该报告在欧科云链研究院内部反响较好,下面就带大家简单的剖析这篇报告的主要内容。 *这篇文章主要由对比分析(已删减&a…...
docker 容器pip、git安装异常;容器内web对外端口ping不通
1、docker 容器pip、git安装异常 错误信息: git clone https://github.com/vllm-project/vllm.git Cloning into ‘vllm’… fatal: unable to access ‘https://github.com/vllm-project/vllm.git/’: Failed to connect to 127.0.0.1 port 10808: Connection ref…...

SpringBoot Mybatis 多数据源 MySQL+Oracle+Redis
一、背景 在SpringBoot Mybatis 项目中,需要连接 多个数据源,连接多个数据库,需要连接一个MySQL数据库和一个Oracle数据库和一个Redis 二、依赖 pom.xml <dependencies><dependency><groupId>org.springframework.boot&l…...
【JavaScript 16】对象继承 原型对象属性 原型链 构造函数属性 instanceof运算符 继承 多重继承 模块
对象继承 原型对象概述instanceof运算符构造函数的继承多重继承模块 A 对象通过继承 B 对象,就能 直接拥有 B 对象的所有属性和方法(利于代码复用) 大部分面向对象的编程语言都是通过类(class)实现对象的继承 但 传统…...

地下管线三维自动建模软件MagicPipe3D V3.0发布
2023年9月1日经纬管网建模系统MagicPipe3D V3.0正式发布,该版本经过众多用户应用和反馈,在三维地下管线建模效果、效率、适配性等方面均有显著提升!MagicPipe3D本地离线参数化构建地下管网模型(包括管道、接头、附属设施等&#x…...

百度等8家企业首批上线大模型服务;大语言模型微调之道
🦉 AI新闻 🚀 百度等8家企业首批上线大模型服务 摘要:百度、字节、中科院旗下8家企业/机构的大模型通过备案,正式面向公众提供服务。百度旗下AI大模型产品文心一言率先开放,用户可下载App或登录官网体验。百川智能也…...

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型
摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...

Qt/C++开发监控GB28181系统/取流协议/同时支持udp/tcp被动/tcp主动
一、前言说明 在2011版本的gb28181协议中,拉取视频流只要求udp方式,从2016开始要求新增支持tcp被动和tcp主动两种方式,udp理论上会丢包的,所以实际使用过程可能会出现画面花屏的情况,而tcp肯定不丢包,起码…...

Redis相关知识总结(缓存雪崩,缓存穿透,缓存击穿,Redis实现分布式锁,如何保持数据库和缓存一致)
文章目录 1.什么是Redis?2.为什么要使用redis作为mysql的缓存?3.什么是缓存雪崩、缓存穿透、缓存击穿?3.1缓存雪崩3.1.1 大量缓存同时过期3.1.2 Redis宕机 3.2 缓存击穿3.3 缓存穿透3.4 总结 4. 数据库和缓存如何保持一致性5. Redis实现分布式…...

3.3.1_1 检错编码(奇偶校验码)
从这节课开始,我们会探讨数据链路层的差错控制功能,差错控制功能的主要目标是要发现并且解决一个帧内部的位错误,我们需要使用特殊的编码技术去发现帧内部的位错误,当我们发现位错误之后,通常来说有两种解决方案。第一…...

关于iview组件中使用 table , 绑定序号分页后序号从1开始的解决方案
问题描述:iview使用table 中type: "index",分页之后 ,索引还是从1开始,试过绑定后台返回数据的id, 这种方法可行,就是后台返回数据的每个页面id都不完全是按照从1开始的升序,因此百度了下,找到了…...

抖音增长新引擎:品融电商,一站式全案代运营领跑者
抖音增长新引擎:品融电商,一站式全案代运营领跑者 在抖音这个日活超7亿的流量汪洋中,品牌如何破浪前行?自建团队成本高、效果难控;碎片化运营又难成合力——这正是许多企业面临的增长困局。品融电商以「抖音全案代运营…...

涂鸦T5AI手搓语音、emoji、otto机器人从入门到实战
“🤖手搓TuyaAI语音指令 😍秒变表情包大师,让萌系Otto机器人🔥玩出智能新花样!开整!” 🤖 Otto机器人 → 直接点明主体 手搓TuyaAI语音 → 强调 自主编程/自定义 语音控制(TuyaAI…...
【python异步多线程】异步多线程爬虫代码示例
claude生成的python多线程、异步代码示例,模拟20个网页的爬取,每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程:允许程序同时执行多个任务,提高IO密集型任务(如网络请求)的效率…...

windows系统MySQL安装文档
概览:本文讨论了MySQL的安装、使用过程中涉及的解压、配置、初始化、注册服务、启动、修改密码、登录、退出以及卸载等相关内容,为学习者提供全面的操作指导。关键要点包括: 解压 :下载完成后解压压缩包,得到MySQL 8.…...
深入浅出Diffusion模型:从原理到实践的全方位教程
I. 引言:生成式AI的黎明 – Diffusion模型是什么? 近年来,生成式人工智能(Generative AI)领域取得了爆炸性的进展,模型能够根据简单的文本提示创作出逼真的图像、连贯的文本,乃至更多令人惊叹的…...