C/C++连接MySQL

本章Gitee仓库地址:mysql连接基本操作

文章目录

    • [1. mysql connect库](#1. mysql connect库)
    • [2. mysql相关接口](#2. mysql相关接口)
      • [2.1 mysql_init()](#2.1 mysql_init())
      • [2.2 mysql_real_connect()](#2.2 mysql_real_connect())
      • [2.3 mysql_query()](#2.3 mysql_query())
      • [2.4 mysql_store_result()](#2.4 mysql_store_result())
        • [2.41 mysql_num_rows](#2.41 mysql_num_rows)
        • [2.42 mysql_num_fields](#2.42 mysql_num_fields)
        • [2.43 mysql_fetch_row](#2.43 mysql_fetch_row)
        • [2.44 mysql_fetch_fields](#2.44 mysql_fetch_fields)
      • [2.5 mysql_free_result()](#2.5 mysql_free_result())

1. mysql connect库

使用C/C++连接MySQL,要先下载mysql的库

shell 复制代码
yum install -y mysql-community-server

在安装mysql的时候,就已经安装了

所需头文件:

shell 复制代码
ls /usr/include/mysql/

动静态库:

shell 复制代码
ls /lib64/mysql/*

如果没有,可以尝试安装

shell 复制代码
yum install mysql-devel

2. mysql相关接口

C语言API函数参考

2.1 mysql_init()

初始化mysql结构体对象

参数:

c++ 复制代码
MYSQL *mysql_init(MYSQL *mysql)

2.2 mysql_real_connect()

连接mysql服务器

参数:

c++ 复制代码
MYSQL *
mysql_real_connect(MYSQL *mysql,
                   const char *host,	//连接的主机地址
                   const char *user,	//用户名
                   const char *passwd,	//密码
                   const char *db,	//所选择的数据库
                   unsigned int port,	//端口号
                   const char *unix_socket,	//套接字
                   unsigned long client_flag)

2.3 mysql_query()

参数:

c++ 复制代码
int mysql_query(MYSQL *mysql,	//初始化的对象
                const char *stmt_str)	//sql语句(无需带';'或'/G')

一般不会写这种客户端出来,这是直接将要执行的sql输入到程序

这里增删改都没问题,只需保证成功即可,这里一定会成功,因为是事务。

select需要将一个个的数据显示出来,让用户获取,所以select还是需要获取上层的。

此外,如果需要显示中文,需要更改一下编码格式

链接建立好之后,默认的latin1,要改成utf8

c++ 复制代码
mysql_set_character_set(my, "utf8");

2.4 mysql_store_result()

参数:

c++ 复制代码
MYSQL_RES *mysql_store_result(MYSQL *mysql)

查询结果以行为单位放在结果集当中

如何理解mysql_res

这些+---+---+|分隔符都是格式化输出显示出来的,并不是在mysql真实存在的

真实存在的是右侧的那些内容,列属性、每列的数据(内容)

查出来的数据,是在内存当中,mysql将所有的数据,读取出来的时候都当作字符串

可以理解为char **pptr[]或者char * ptr[][]

2.41 mysql_num_rows

语法:

c++ 复制代码
my_ulonglong mysql_num_rows(MYSQL_RES *result)

提取有多少行

2.42 mysql_num_fields

语法:

c++ 复制代码
unsigned int mysql_num_fields(MYSQL_RES *result)

提取有多少列

2.43 mysql_fetch_row

语法:

c++ 复制代码
MYSQL_ROW mysql_fetch_row(MYSQL_RES *result)

对结果集进行操作,拿到其中的一行

类似与C++的迭代器

2.44 mysql_fetch_fields

语法:

c++ 复制代码
MYSQL_FIELD *mysql_fetch_fields(MYSQL_RES *result)

获取表结构的属性

c++ 复制代码
MYSQL_RES *res = mysql_store_result(my);
    my_ulonglong rows = mysql_num_rows(res);
    my_ulonglong fields = mysql_num_fields(res);
    std::cout << "行:" << rows << std::endl;
    std::cout << "列:" << fields << std::endl;

    //属性
    MYSQL_FIELD *field_array = mysql_fetch_field(res);
    for(int i = 0; i < fields; i++)
    {
        //格式化输出
        std::cout << std::left << std::setw(15) << field_array[i].name << "\t";
    }
    std::cout << std::endl;

    //内容(数据)
    for(int i = 0; i < rows; i++)
    {
        MYSQL_ROW row = mysql_fetch_row(res);
        for(int j = 0; j < fields; j++)
        {
            std::cout << std::left << std::setw(15) << row[j] << "\t";
        }    
        std::cout << std::endl;
    }

2.5 mysql_free_result()

提取的内容存在内存当中,系统给我们malloc好了,用完需要我们自己释放

c++ 复制代码
void mysql_free_result(MYSQL_RES *result)
相关推荐
xcLeigh4 小时前
Python 项目实战:用 Flask 实现 MySQL 数据库增删改查 API
数据库·python·mysql·flask·教程·python3
rainbow68894 小时前
Linux文件描述符与重定向原理
c++
Fleshy数模5 小时前
MySQL 表创建全攻略:Navicat 图形化与 Xshell 命令行双模式实践
linux·mysql
Nandeska5 小时前
15、基于MySQL的组复制
数据库·mysql
CodeSheep程序羊5 小时前
拼多多春节加班工资曝光,没几个敢给这个数的。
java·c语言·开发语言·c++·python·程序人生·职场和发展
I'mChloe5 小时前
PTO-ISA 深度解析:PyPTO 范式生成的底层指令集与 NPU 算子执行的硬件映射
c语言·开发语言
编程小白20265 小时前
从 C++ 基础到效率翻倍:Qt 开发环境搭建与Windows 神级快捷键指南
开发语言·c++·windows·qt·学习
2的n次方_5 小时前
Runtime 内存管理深化:推理批处理下的内存复用与生命周期精细控制
c语言·网络·架构
AllData公司负责人5 小时前
AllData数据中台-数据同步平台【Seatunnel-Web】整库同步MySQL同步Doris能力演示
大数据·数据库·mysql·开源
嵌入小生0076 小时前
标准IO---核心函数接口延续(嵌入式Linux)
c语言·vscode·vim·嵌入式·小白·标准io·函数接口