c++中操作数据库的常用函数

ops/2024/11/24 18:49:20/

在C++中操作数据库,尤其是MySQL数据库,主要通过MySQL提供的C API或MySQL Connector/C++库来实现。这些库提供了一系列的函数,使得开发者能够在C++应用程序中执行数据库的连接、查询、更新、删除等操作。以下是C++中操作MySQL数据库的一些常用函数,以及它们的功能和使用方法。

连接数据库

1. mysql_init

初始化一个MySQL连接句柄,为后续的数据库操作做准备。

 

cpp

深色版本

MYSQL *mysql_init(MYSQL *mysql);

如果传入 NULL,函数会自动分配一个 MYSQL 对象。如果初始化失败,返回 NULL

1

2. mysql_real_connect

尝试建立到MySQL服务器的连接。

 

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 client_flag);
  • mysql: 由 mysql_init 初始化的句柄。
  • host: 连接的MySQL服务器的地址。
  • user: 连接的服务器的用户名。
  • passwd: 连接的服务器的密码。
  • db: 默认选择的数据库名称。
  • port: 连接的服务器的端口,默认为3306。
  • unix_socket: 通信管道或socket,通常设为 NULL
  • client_flag: 客户端标志位,通常设为 0

如果连接成功,返回句柄;失败返回 NULL

1

设置字符集

3. mysql_set_character_set

设置当前客户端的字符集,以确保字符编码的一致性。

 

cpp

深色版本

int mysql_set_character_set(MYSQL *mysql, const char *csname);
  • mysql: 初始化完成的句柄。
  • csname: 字符集名称,如 "utf8"

成功返回 0,失败返回非零值。

1

执行SQL语句

4. mysql_query

执行一个SQL语句。

 

cpp

深色版本

int mysql_query(MYSQL *mysql, const char *stmt_str);
  • mysql: 初始化完成的句柄。
  • stmt_str: 要执行的SQL语句。

成功返回 0,失败返回非零值。

1

5. mysql_real_query

类似于 mysql_query,但允许执行包含二进制数据的语句。

 

cpp

深色版本

int mysql_real_query(MYSQL *mysql, const char *stmt_str, unsigned long length);
  • length: SQL语句的长度。

成功返回 0,失败返回非零值。

9

处理查询结果

6. mysql_store_result

保存查询结果到本地。

 

cpp

深色版本

MYSQL_RES *mysql_store_result(MYSQL *mysql);
  • mysql: 初始化完成的句柄。

成功返回结果集的指针,失败返回 NULL

1

7. mysql_fetch_row

遍历结果集,获取单行数据。

 

cpp

深色版本

MYSQL_ROW mysql_fetch_row(MYSQL_RES *result);
  • result: 保存到本地的结果集地址。

返回值是一个 char ** 类型的指针,将每条数据做成了字符串指针数组,row[0] 为第一列,row[1] 为第二列,依此类推。

1

8. mysql_num_rows

获取结果集中的行数。

 

cpp

深色版本

uint64_t mysql_num_rows(MYSQL_RES *result);
  • result: 保存到本地的结果集地址。

返回结果集中数据的条数。

1

9. mysql_num_fields

获取结果集中列的个数。

 

cpp

深色版本

unsigned int mysql_num_fields(MYSQL_RES *result);
  • result: 保存到本地的结果集地址。

返回结果集中每条数据的列数。

1

清理资源

10. mysql_free_result

释放结果集资源。

 

cpp

深色版本

void mysql_free_result(MYSQL_RES *result);
  • result: 保存到本地的结果集地址。

没有返回值。

1

11. mysql_close

关闭数据库客户端连接,销毁句柄。

 

cpp

深色版本

void mysql_close(MYSQL *mysql);
  • mysql: 初始化完成的句柄。

没有返回值。

1

错误处理

12. mysql_error

获取MySQL接口执行错误的原因。

 

cpp

深色版本

const char *mysql_error(MYSQL *mysql);
  • mysql: 初始化完成的句柄。

返回错误信息的字符串。

1

示例代码

以下是一个简单的示例,展示了如何使用上述函数连接MySQL数据库、执行查询并处理结果集。

 

cpp

深色版本

#include <iostream>
#include <mysql.h>int main() {MYSQL *conn = mysql_init(NULL);// 连接数据库if (!mysql_real_connect(conn, "localhost", "root", "password", "testdb", 0, NULL, 0)) {std::cerr << "Error connecting to database: " << mysql_error(conn) << std::endl;return 1;}// 设置字符集if (mysql_set_character_set(conn, "utf8") != 0) {std::cerr << "Error setting character set: " << mysql_error(conn) << std::endl;return 1;}// 执行查询if (mysql_query(conn, "SELECT * FROM users")) {std::cerr << "Error executing query: " << mysql_error(conn) << std::endl;return 1;}// 保存查询结果MYSQL_RES *result = mysql_store_result(conn);if (result == NULL) {std::cerr << "Error storing result: " << mysql_error(conn) << std::endl;return 1;}// 获取结果集中的行数和列数unsigned int num_fields = mysql_num_fields(result);unsigned int num_rows = mysql_num_rows(result);std::cout << "Number of rows: " << num_rows << std::endl;std::cout << "Number of fields: " << num_fields << std::endl;// 遍历结果集MYSQL_ROW row;while ((row = mysql_fetch_row(result))) {for (unsigned int i = 0; i < num_fields; i++) {std::cout << row[i] << "\t";}std::cout << std::endl;}// 释放结果集资源mysql_free_result(result);// 关闭数据库连接mysql_close(conn);return 0;
}

总结

通过上述函数,C++开发者可以方便地在应用程序中实现与MySQL数据库的交互。这些函数涵盖了从连接数据库到执行查询、处理结果集再到清理资源的完整流程,为开发者提供了强大的工具来管理和操作数据库数据。

1


http://www.ppmy.cn/ops/136374.html

相关文章

【机器学习】Lesson 5 - K近邻(KNN)分类/回归

目录 背景 一、算法介绍 1. 基本原理 1.1 概述 1.2 常用距离 1.3 模型参数 2. 适用场景 2.1 分类 适用场景 KNN 分类的优缺点 2.2 回归 适用场景 KNN 回归的优缺点 3. 适用数据集特征 3.1 特征维度&#xff08;维数&#xff09; 3.2 样本量&#xff08;行数&am…

C 语言复习总结记录二

C 语言复习总结记录二 一 控制语句 1、语句的分类 表达式语句函数调用语句复合语句控制语句空语句 控制语句 控制程序的执行流程&#xff0c;实现程序的各种结构方式 C 语言支持三种结构 &#xff1a;顺序结构、选择结构、循环结构&#xff0c;由特定的语句定义符组成C语言…

高性能 ArkUI 应用开发:复杂 UI 场景中的内存管理与 XML 优化

本文旨在深入探讨华为鸿蒙HarmonyOS Next系统(截止目前API12)的技术细节,基于实际开发实践进行总结。 主要作为技术分享与交流载体,难免错漏,欢迎各位同仁提出宝贵意见和问题,以便共同进步。 本文为原创内容,任何形式的转载必须注明出处及原作者。 在开发高性能 ArkUI 应…

AFC自动售检票系统在地铁行业中,由于历史原因,各个终端设备采用了不同厂家的业务软件,如何进行软件一体化的措施?

摘要: 在地铁行业中,AFC(自动售检票)系统由于历史原因可能存在设备厂商不同、软件版本不一、接口标准不统一等问题。为实现软件的一体化管理和运行,需要综合考虑技术、架构、流程和成本等因素。以下是实现AFC系统软件一体化的具体措施: 1. 建立统一的接口标准 问题:各厂…

Python爬虫:获取1688关键词API接口数据

引言 在当今的电子商务领域&#xff0c;数据的价值不言而喻。对于商家来说&#xff0c;掌握行业关键词趋势是洞察市场动态、优化产品布局的重要手段。1688作为中国领先的B2B电商平台&#xff0c;提供了海量的商品数据。本文将介绍如何使用Python编写爬虫程序&#xff0c;通过A…

三次握手后的数据传输

一旦三次握手成功完成&#xff0c;TCP连接便正式建立&#xff0c;双方可以开始传输数据。在这个阶段&#xff0c;TCP协议利用其独特的可靠性和流控机制&#xff0c;确保数据的有序、无差错传输。 序列号与确认号&#xff1a;在数据传输过程中&#xff0c;TCP会为每个报文段分配…

Python + 深度学习从 0 到 1(00 / 99)

希望对你有帮助呀&#xff01;&#xff01;&#x1f49c;&#x1f49c; 如有更好理解的思路&#xff0c;欢迎大家留言补充 ~ 一起加油叭 &#x1f4a6; 欢迎关注、订阅专栏 【深度学习从 0 到 1】谢谢你的支持&#xff01; ⭐ 什么是深度学习&#xff1f; 人工智能、机器学习与…

设置jenkins时区记录

System.setProperty(org.apache.commons.jelly.tags.fmt.timeZone, Asia/Shanghai)