C++:连接MySQL数据库(一)

1、MySQL提供的连接相关API
  • C和C++都提供了访问MySQL的API接口,连接过程也较为简单
  • 主要是下面两个函数
    • mysql_init:初始化创建的MySQL结构体,如果传入空则自动分配一个。失败返回NULL,成功返回一个指针,它是线程不安全的,其内部也会自动调用mysql_library_init函数
    • mysql_library_init函数:主要在多线程情况下使用,用于初始化服务连接,它实际上是一个宏函数(mysql_server_init)
    • mysql_library_end函数:主要在多线程情况下使用,用于关闭服务连接,实际上是一个宏函数(mysql_server_end)
    • mysql_close函数:用于释放MySQL结构体对象
cpp 复制代码
MYSQL* mysql_init(MYSQL *mysql);

mysql_library_init(int argc, char **argv, char **groups);

mysql_library_end();

void  mysql_close(MYSQL *sock);
  • mysql_real_connect函数:用于与MySQL数据库建立连接

    • mysql:初始化的结构体对象
    • host、user、passwd、db、port:分别对应MySQL服务器地址、用户名、密码、库名、端口
    • unix_socket:这个是Linux网络编程里面的知识表示,Socket套接字,可以传入0让连接函数自己创建
    • clientflag:连接可以做一些设置,是否希望此次建立的连接是否需要同一些其他特性需求,例如:允许多查询、返回表信息等等,默认传0
    • 返回值:成功返回MySQL结构体指针,失败返回NULL
    cpp 复制代码
    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 clientflag);
  • mysql_options函数:用于设置一些连接超时、断开重连等

    • MYSQL_OPT_CONNECT_TIMEOUT:连接超时设置,可以设置连接多久连不上就超时,减少阻塞事件
    • MYSQL_OPT_READ_TIMEOUT:设置读(查询)超时
    • MYSQL_OPT_RECONNECT:断开重连
      • 成功返回0,失败返回非0
    cpp 复制代码
    int mysql_options(MYSQL *mysql,enum mysql_option option, const void *arg);
2、C++连接MySQL
  • 在使用Linux环境下如果是用Makefile编译需要加入一些编译参数-lmysqlclient -I/usr/local/mysql
cpp 复制代码
#include <iostream>
#include <mysql/mysql.h>
using namespace std;

int main(int argc, char *argv[])
{
    MYSQL mysql;
    // 1. 初始化mysql结构体并且初始化服务连接环境
    mysql_init(&mysql);
    const char *host = "127.0.0.1";
    const char *user = "root";
    const char *password = "123456";
    const char *db = "mysql";
    int timeout = 3;
    // 2. 连接超时时长设置
    mysql_options(&mysql, MYSQL_OPT_CONNECT_TIMEOUT, &timeout);

    // 3. 断开重连设置
    int reconnect = 1;
    mysql_options(&mysql, MYSQL_OPT_RECONNECT, &reconnect);

    // 4. MySQL连接建立
    if(!mysql_real_connect(&mysql, host, user, password, db, 3306, 0, 0)){
        std::cout << "mysql connect failed!" << mysql_error(&mysql) << std::endl;
    }
    else{
        std::cout << "mysql connect " << host << " success!" << std::endl;
    }
    cout << "Hello World!\n" << endl;

    // 5. 释放mysql结构体
    mysql_close(&mysql);
    return 0;
}
相关推荐
DevilSeagull13 分钟前
MySQL(2) 客户端工具和建库
开发语言·数据库·后端·mysql·服务
xrui5822 分钟前
2026实战:深度解析 Gemini 3.1 镜像站函数调用在自动化运维工单中的应用
linux·服务器·网络
HackTwoHub28 分钟前
Linux 内核史诗级本地提权 全网深度复现、原理完整分析( CVE-2026-31431)
linux·运维·安全·web安全·网络安全·代码审计·安全架构
AI进化营-智能译站39 分钟前
ROS2 C++开发系列16-智能指针管理传感器句柄|告别ROS2节点内存泄漏与野指针
java·c++·算法·ai
报错小能手40 分钟前
好好讲讲移动构造 移动赋值
c++
syker1 小时前
AIFerric深度学习框架:自研全栈AI基础设施的技术全景
开发语言·c++
她说彩礼65万1 小时前
C语言 文件
linux·服务器·c语言
txg6661 小时前
自动驾驶领域热点简报(2026-04-26 ~ 2026-05-03)
linux·人工智能·自动驾驶
远洪1 小时前
claude code 国内安装使用
数据库·mysql
二哈赛车手1 小时前
新人笔记---ES和kibana启动问题以及一些常用的linux的错误排查方法,以及ES,数据库泄密解决方案[超详细]
java·linux·数据库·spring boot·笔记·elasticsearch