【MySQL】11.使用 C 语言访问 MySQL

使用C语言访问MySQL

  • 一.检查第三方库是否配置成功
  • 二.MySQL 常用接口
    • 1.创建,销毁操作句柄
    • 2.使用句柄连接数据库
    • 3.向 mysqld 发送指令
    • 4.查询相关函数
  • 三.使用示例

一.检查第三方库是否配置成功

想要使用代码连接数据库,必须使用 MySQL 官方提供的第三方库。早在我们第一节使用 yum 安装 MySQL 的时候,
就安装了三个东西:MySQL 客户端,MySQL 服务端,MySQL 开发包(库)。所以我们只需检查一下环境是否就绪。

//1.检查是否有MySQL库
[liuyi@centos-7 usr]$ ls /usr/lib64/mysql/
libmysqlclient.a        libmysqlclient_r.so.18.1.0  libmysqlclient.so.18      libmysqlclient.so.20       libmysqlservices.a  plugin
libmysqlclient_r.so.18  libmysqlclient.so           libmysqlclient.so.18.1.0  libmysqlclient.so.20.3.31  mecab//2.检查是否有MySQL头文件
[liuyi@centos-7 usr]$ ls /usr/include/mysql/
big_endian.h              keycache.h       my_command.h        my_getopt.h         mysqld_ername.h  mysqlx_ername.h    my_xml.h                    plugin_validate_password.h  thr_cond.h
binary_log_types.h        little_endian.h  my_compiler.h       my_global.h         mysqld_error.h   mysqlx_error.h     plugin_audit.h              sql_common.h                thr_mutex.h
byte_order_generic.h      m_ctype.h        my_config.h         my_list.h           mysql_embed.h    mysqlx_version.h   plugin_ftparser.h           sql_state.h                 thr_rwlock.h
byte_order_generic_x86.h  m_string.h       my_config_x86_64.h  mysql               mysql.h          my_sys.h           plugin_group_replication.h  sslopt-case.h               typelib.h
decimal.h                 my_alloc.h       my_dbug.h           mysql_com.h         mysql_time.h     my_thread.h        plugin.h                    sslopt-longopts.h
errmsg.h                  my_byteorder.h   my_dir.h            mysql_com_server.h  mysql_version.h  my_thread_local.h  plugin_keyring.h            sslopt-vars.h
如果以上东西没有,则执行以下命令安装开发包:
sudo yum install -y mysql-devel
#include <mysql/mysql.h>
#include <iostream>
using namespace std;int main()
{cout << "mysql client version: " << mysql_get_client_info() << endl;return 0;
}//编译命令如下:
//g++ -o test test.cc -std=c++11 -L /usr/lib64/mysql -l mysqlclient
//如果编译成功,则说明环境没有问题
[liuyi@centos-7 test_db]$ ./test 
mysql client version: 5.7.44

二.MySQL 常用接口

MySQL 官方文档

1.创建,销毁操作句柄

MYSQL* mysql_init(MYSQL* mysql);
功能:创建一个mysql对象,这就是我们操作的句柄
返回值:如果返回NULL则创建失败,否则返回一个创建出的对象void mysql_close(MYSQL* mysql);
功能:销毁mysql对象

2.使用句柄连接数据库

MYSQL* mysql_real_connect(MYSQL *mysql, //句柄const char *host,    //mysqld所在主机const char *user,    //mysql用户名const char *passwd,  //登录密码const char *db,      //数据库名unsigned int port,   //mysqld所在端口const char *unix_socket,   //一般设为nullptrunsigned long client_flag) //一般设为0功能:连接数据库
返回值:连接失败返回nullptr,连接成功返回句柄本身

3.向 mysqld 发送指令

int mysql_query(MYSQL *mysql,const char *stmt_str)
功能:向mysqld发送指令执行
返回值:0表示语句执行成功,非0表示执行失败    int mysql_set_character_set(MYSQL *mysql,const char *csname)    
功能:设置当前连接的字符串编码格式,必须让它和mysqld的编码格式保持一致,否则中文会乱码     
返回值:为0则设置成功

4.查询相关函数

select查询到的数据会保存在MYSQL对象中MYSQL_RES* mysql_store_result(MYSQL *mysql);
功能:将保存在MySQL对象中的数据进行整合,把查询结果保存到MYSQL_RES对象中
返回值:为nullptr表示失败
说明:
MYSQL_RES也是第三方库定义的一个结构体类型,其内部维护了一个char**的数组,
以后处理select结果会频繁用到该对象;
mysql_store_result内部肯定会malloc一段空间用于保存结果,最后一定要调用相应函数释放以免内存泄露unsigned int mysql_num_rows(MYSQL_RES *res); 
功能:返回表的行数(不包含字段行)
unsigned int mysql_num_fields(MYSQL_RES *res);
功能:返回表的列数(不包含字段行)MYSQL_ROW mysql_fetch_row(MYSQL_RES *result); 
功能:获取一行的结果,每次调用后会自动迭代
返回值:为nullptr表示获取失败
说明:MYSQL_ROW是对char**typedefMYSQL_FIELD *mysql_fetch_fields(MYSQL_RES *res);
功能:返回该表的所有字段的详细信息
返回值:为nullptr表示获取失败
说明:MYSQL_FIELD是一个结构体类型,包含一个字段的详细信息,如字段名,属性,所属表的名称等void mysql_free_result(MYSQL_RES* res)
功能:释放mysql_store_result中申请的空间,释放后就不要试图访问res了

在这里插入图片描述

三.使用示例

#include <mysql/mysql.h>
#include <iostream>
#include <cassert>const char *host = "127.0.0.1"; //写localhost也行
const char *user = "ly";
const char *password = "**********"; //密码不方便透露
const char *db = "test_db";
unsigned int port = 3306;
using namespace std;int main()
{//1.创建句柄MYSQL *mysql = mysql_init(nullptr);if (mysql == nullptr){cout << "创建MySQL对象失败" << endl;return 1;}//2.连接数据库并修改本次连接中客户端的编码方式assert(mysql_real_connect(mysql, host, user, password, db, port, nullptr, 0) != nullptr);mysql_set_character_set(mysql, "utf8");//3.执行建表,插入,查询语句assert(mysql_query(mysql, "create table test_tb(id int, name varchar(20))") == 0);assert(mysql_query(mysql, "insert into test_tb values(1, '张三')") == 0);assert(mysql_query(mysql, "insert into test_tb values(2, '李四')") == 0);assert(mysql_query(mysql, "select * from test_tb") == 0);//4.将查询结果保存到res中MYSQL_RES *res = mysql_store_result(mysql);//5.处理查询结果int rows = mysql_num_rows(res);int cols = mysql_num_fields(res);MYSQL_FIELD *fields_array = mysql_fetch_fields(res);for (int i = 0; i < cols; i++){cout << fields_array[i].name << "\t";}cout << endl;for (int i = 0; i < rows; i++){char **line = mysql_fetch_row(res);for (int j = 0; j < cols; j++){cout << line[j] << "\t";}cout << endl;}//6.释放查询结果mysql_free_result(res);//7.销毁句柄mysql_close(mysql);return 0;
}//编译运行结果:
[liuyi@centos-7 test_db]$ ./test 
id      name
1       张三
2       李四

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

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

相关文章

redis服务器同 redis 集群

搭建redis服务器 修改服务运行参数 常用命令常用命令 创建redis集群 准备做集群的主机&#xff0c;不允许存储数据、不允许设置连接密码 配置服务器&#xff1a; 1、在任意一台redis服务器上都可以执行创建集群的命令。 2、--cluster-replicas 1 给每个master服务器分配1台…

Java之反射和枚举及lambda表达式

1.反射 1 定义 Java 的反射&#xff08; reflflection &#xff09;机制是在 运行 状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的 所有属性和方法 &#xff1b;对于任 意一个对象&#xff0c;都能够调用它的任意方法和属性&#xff0c;既然能拿到那么&…

链表面试练习习题(Java)

1. 思路&#xff1a; 创建两个链表&#xff0c;一个用来记录小于x的结点&#xff0c;一个用来记录大于等于x的结点&#xff0c;然后遍历完原链表后&#xff0c;将小于x的链表和大于等于x的链表进行拼接即可 public class Partition { public ListNode partition(ListNode pH…

【Java面向对象】抽象类和接口

文章目录 1.抽象类2.常见的抽象类2.1 Number类2.2 Calendar 和GregorianCalendar 3.接口4.常见接口4.1 Comparable 接口4.2 Cloneable 接口4.3 深浅拷贝 5.类的设计原则 1.抽象类 在继承的层次结构中&#xff0c;每个新的子类都使类变得更加明确和具体。如果从一个子类向父类追…

IDEA中创建一个SpringBoot项目并提交到git仓库(日常开发-保姆级手把手超详细截图)

日常开发 第一步&#xff1a; 第二步&#xff1a; &#x1f388;边走、边悟&#x1f388;迟早会好 Git是什么&#xff1f; Git是一款免费、开源的分布式版本控制系统&#xff0c;用于敏捷高效地处理任何或小或大的项目。 Git是一个开源的分布式版本控制系统&#xff0c;可…

【保卫花果山】游戏

游戏介绍 拯救花果山是一款玩家能够进行趣味闯关的休闲类游戏。拯救花果山中玩家需要保护花果山的猴子&#xff0c;利用各种道具来防御妖魔鬼怪的入侵&#xff0c;游戏中玩家需要面对的场景非常的多样&#xff0c;要找到各种应对敌人的方法。拯救花果山里玩家可以不断的进行闯…

[米联客-安路飞龙DR1-FPSOC] FPGA基础篇连载-20 读写I2C接口的RTC时钟芯片

软件版本&#xff1a;Anlogic -TD5.9.1-DR1_ES1.1 操作系统&#xff1a;WIN10 64bit 硬件平台&#xff1a;适用安路(Anlogic)FPGA 实验平台&#xff1a;米联客-MLK-L1-CZ06-DR1M90G开发板 板卡获取平台&#xff1a;https://milianke.tmall.com/ 登录“米联客”FPGA社区 ht…

超声波清洗机选哪款比较好?推荐四款性价比超高型号

2024年的超声波清洗机技术已经取得了显著进步。市面上的超声波清洗机种类繁多&#xff0c;功能各异&#xff0c;有的可以彻底清洁眼镜&#xff0c;有的还能进行消毒等。今天&#xff0c;我向大家推荐几款我亲自测试过的超声波清洗机&#xff0c;它们的性能都相当优秀&#xff0…

分布式搜索引擎ES-elasticsearch入门

1.分布式搜索引擎&#xff1a;luceneVS Solr VS Elasticsearch 什么是分布式搜索引擎 搜索引擎&#xff1a;数据源&#xff1a;数据库或者爬虫资源 分布式存储与搜索&#xff1a;多个节点组成的服务&#xff0c;提高扩展性(扩展成集群) 使用搜索引擎为搜索提供服务。可以从海量…

Android获取当前屏幕显示的是哪个activity

在 Android 中&#xff0c;要获取当前屏幕显示的 Activity&#xff0c;可以使用以下几种方法&#xff1a; 方法一&#xff1a;使用 ActivityManager 获取当前运行的任务信息 这是一个常见的方法&#xff0c;尽管从 Android 5.0 (API 21) 开始&#xff0c;有些方法变得不太可靠…

Java语言程序设计——篇五(2)

有关数组的方法 &#x1f4a5;增强的for循环实战演练 数组元素的复制实战演练 数组参数与返回值&#x1f4a2;java.util.Arrays类数组的排序实战演练 元素的查找数组元素的复制填充数组元素数组的比较实战演练 &#x1f4a5;增强的for循环 增强的for循环&#xff0c;它是Java …

MySQL(6)内置函数,复合查询.

目录 1.内置函数; 2.复合查询; 1.内置函数: 1.1 日期函数: 时分秒: 时间戳: 基本日期上加日期: 基本日期减去日期: 日期相差天数: &#x1f330; 创建一张表&#xff0c;记录生日: 创建一个留言表: 显示所有留言信息&#xff0c;发布日期只显示日期&#xff0c;不用显示时间: …

tree组件实现折叠与展开功能(方式1 - expandedTree计算属性)

本示例节选自vue3最新开源组件实战教程大纲&#xff08;持续更新中&#xff09;的tree组件开发部分。考察响应式对象列表封装和computed计算属性的使用&#xff0c;以及数组reduce方法实现结构化树拍平处理的核心逻辑。 实现思路 第一种方式&#xff1a;每次折叠或展开后触发…

node管理工具nvm

使用nvm可以切换node版本、命令安装node 一、nvm下载安装 1、下载 nvm-setup.zip - 蓝奏云 在github可以选择最新版的【nvm】&#xff1a;&#xff08;nvm-windows 最新下载地址&#xff09;Releases coreybutler/nvm-windows GitHub nvm-noinstall.zip&#xff1a; 这个…

基于edk2编译arm64版intel网卡undi驱动

本文介绍如何在edk2下面编译intel undi驱动。 edk2版本edk2-stable202305 文章目录 一、源码下载二、驱动编译2.1 第一次编译IntelXGigUndi及修改2.2 Intel其他undi驱动编译三、驱动二进制文件四、驱动使用方法一、源码下载 intel 网卡驱动下载地址 https://www.intel.com/con…

MySQL 数据库 - 事务

MySQL 数据库&#xff08;基础&#xff09;- 事务 事务简介 事务 是一组操作集合&#xff0c;他是一个不可分割的工作单位&#xff0c;事务会把所有的操作看作是一个整体一起向系统发送请求&#xff0c;即这些操作要么同时成功&#xff0c;要么同时失败。 比如&#xff1a;张…

C#医学影像管理系统源码(VS2013)

目录 一、概述 二、系统功能 系统维护 工作站 三、功能介绍 影像采集 统计模块 专业阅片 采集诊断报告 报告管理 一、概述 医学影像存储与传输系统&#xff08;PACS&#xff09;是一种集成了影像存储、传输、管理和诊断功能的系统。它基于数字化成像技术、计算机技术和…

STM32CubeMX配置STM32G071输入捕获(HAL库开发)

1.时钟配置HSI主频配置64M 2.配置好串口&#xff0c;选择异步模式 3.配置TIM1_CH1产生1KHz的信号&#xff0c;主频64MHz&#xff0c;分频&#xff08;64-1&#xff09;&#xff0c;计数周期&#xff08;1000-1&#xff09;&#xff0c;这样即可生成1KHz信号。 4.配置TIM3_CH1和…

农业旅游与乡村旅游:融合绿色田野与诗意远方的经济新篇章

在这个快节奏的时代&#xff0c;人们对于回归自然、体验淳朴生活的渴望日益增强。农业旅游与乡村旅游&#xff0c;作为新兴的旅游形态&#xff0c;正逐步成为连接城市与乡村的桥梁&#xff0c;不仅为都市人提供了一片心灵的栖息地&#xff0c;也为农村地区带来了前所未有的发展…

昇思25天学习打卡营第15天|munger85

K近邻算法实现红酒聚类 现在数据集这个就是红酒的分类的数据集红酒每一个都会有很多的属性有三个属性下载数据集&#xff0c;这个是红酒的分类的数据集&#xff0c;红酒每一个都会有很多的属性&#xff0c;有三个属性。这十三个属性就可以用来分辨它是哪一个13个属性就可以用来…