首页 > 后端开发 > C++ > 正文

c++怎么连接和操作MySQL数据库_c++数据库访问与SQL执行实例

冰火之心
发布: 2025-11-17 18:29:17
原创
944人浏览过
答案是使用MySQL C API连接数据库需先安装开发库,包含mysql.h头文件,调用mysql_init初始化,mysql_real_connect建立连接,执行查询或插入操作后释放资源。

c++怎么连接和操作mysql数据库_c++数据库访问与sql执行实例

在C++中连接和操作MySQL数据库,通常使用MySQL官方提供的C API(即 MySQL Connector/C)或其封装库如 MySQL++。本文以原生的 MySQL C API 为例,介绍如何连接、查询、插入数据,并给出完整实例。

1. 环境准备与依赖安装

确保系统已安装 MySQL 开发库:

  • Ubuntu/Debian:sudo apt-get install libmysqlclient-dev
  • CentOS/RHEL:sudo yum install mysql-devel
  • Windows:下载并配置 MySQL Connector/C,设置头文件和库路径

编译时需链接库:-lmysqlclient

2. 包含头文件并初始化连接

使用 <mysql.h> 提供的接口进行数据库操作。

立即学习C++免费学习笔记(深入)”;

#include <iostream>
#include <mysql.h>

int main() {
    MYSQL *conn;
    conn = mysql_init(NULL);

    if (!conn) {
        std::cerr << "初始化失败" << std::endl;
        return 1;
    }

    // 连接数据库
    if (!mysql_real_connect(conn, "localhost", "root", "password",
                           "testdb", 3306, NULL, 0)) {
        std::cerr << "连接失败: " << mysql_error(conn) << std::endl;
        mysql_close(conn);
        return 1;
    }

    std::cout << "数据库连接成功!" << std::endl;
登录后复制

说明:

  • mysql_init() 初始化连接句柄
  • mysql_real_connect() 建立连接,参数依次为:主机、用户名、密码、数据库名、端口等

3. 执行SQL语句

使用 mysql_query() 执行非查询语句,用 mysql_use_result()mysql_store_result() 处理查询结果。

阿里云-虚拟数字人
阿里云-虚拟数字人

阿里云-虚拟数字人是什么? ...

阿里云-虚拟数字人 2
查看详情 阿里云-虚拟数字人
    // 插入数据
    const char *insert_sql = "INSERT INTO users (name, age) VALUES ('张三', 25)";
    if (mysql_query(conn, insert_sql)) {
        std::cerr << "插入失败: " << mysql_error(conn) << std::endl;
    } else {
        std::cout << "插入成功,影响行数: " << mysql_affected_rows(conn) << std::endl;
    }

    // 查询数据
    if (mysql_query(conn, "SELECT id, name, age FROM users")) {
        std::cerr << "查询失败: " << mysql_error(conn) << std::endl;
    } else {
        MYSQL_RES *result = mysql_store_result(conn);
        if (result) {
            MYSQL_ROW row;
            while ((row = mysql_fetch_row(result))) {
                std::cout << "ID: " << row[0] 
                          << ", 姓名: " << row[1] 
                          << ", 年龄: " << row[2] << std::endl;
            }
            mysql_free_result(result);
        }
    }
登录后复制

关键函数说明:

  • mysql_query():执行SQL字符串
  • mysql_store_result():将结果集全部取回内存
  • mysql_fetch_row():逐行获取数据,返回字符串数组
  • mysql_free_result():释放结果集资源

4. 预处理语句(防SQL注入)

对于带参数的操作,推荐使用预处理语句。

    MYSQL_STMT *stmt = mysql_stmt_init(conn);
    const char *sql = "INSERT INTO users (name, age) VALUES (?, ?)";
    
    if (mysql_stmt_prepare(stmt, sql, strlen(sql))) {
        std::cerr << "预处理失败: " << mysql_stmt_error(stmt) << std::endl;
        mysql_stmt_close(stmt);
        return 1;
    }

    // 绑定参数
    MYSQL_BIND bind[2];
    std::string name = "李四";
    int age = 30;

    memset(bind, 0, sizeof(bind));
    bind[0].buffer_type = MYSQL_TYPE_STRING;
    bind[0].buffer = (char*)name.c_str();
    bind[0].buffer_length = name.length();

    bind[1].buffer_type = MYSQL_TYPE_LONG;
    bind[1].buffer = &age;

    if (mysql_stmt_bind_param(stmt, bind)) {
        std::cerr << "绑定参数失败: " << mysql_stmt_error(stmt) << std::endl;
    }

    if (mysql_stmt_execute(stmt)) {
        std::cerr << "执行失败: " << mysql_stmt_error(stmt) << std::endl;
    } else {
        std::cout << "预处理插入成功" << std::endl;
    }

    mysql_stmt_close(stmt);
登录后复制

5. 关闭连接与清理

程序结束前务必释放资源。

    mysql_close(conn);
    return 0;
}
登录后复制

完整编译命令(Linux):

g++ -o db_example db_example.cpp -lmysqlclient

注意事项:

  • 所有操作应包含错误检查
  • 多线程环境下需确保连接安全或使用连接池
  • 生产环境建议封装成类管理连接生命周期
基本上就这些。通过 MySQL C API 可以高效地在 C++ 中操作数据库,虽然较底层,但性能好、控制力强。

以上就是c++++怎么连接和操作MySQL数据库_c++数据库访问与SQL执行实例的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号