C++连接mysql数据库并读取数据的具体步骤

 更新时间:2023年04月21日 09:41:11   作者:编程砖家  
在实际开发中我们经常需要对数据库进行访问,针对不同类型的数据库(如MySQL、sqLite、Access、Excel等),如果采用不同的方法进行连接,会把我们搞崩溃,下面这篇文章主要给大家介绍了关于C++连接mysql数据库并读取数据的具体步骤,需要的朋友可以参考下

1、需要包含mysql API的头文件

如果需要连接都本地的mysql数据库,前提是本地要已经安装了mysql数据库。这里要用到一些mysql的API,比如连接数据库、执行查询语句等操作,这些接口都包含在下面的头文件中:

#include <mysql/mysql.h>

2、连接mysql具体步骤

这里大致可以分为四个主要步骤:

1、连接mysql数据库

1、连接mysql数据库

显然,如果要获取mysql数据中数据,首先要连接数据库,获得一个可以操作数据库的句柄。

2、执行查询语句,即选择我们需要的数据

就是执行查询语句,查询我们需要的数据。查询到的数据会保存在一个叫做结果集的地方。

3、从结果集中获取需要的数据

利用相关的接口函数,从结果集中获取每一行各地字段的数据。

4、从结果集中提取每行各个字段的信息

5、释放资源,包括结果集合mysql句柄

下面具体讲解一下几个必须用到的关键接口函数。

2.1 mysql_real_connect

该函数用于连接运行在主机上的数据库引擎,如果连接成功,将获得可以操作数据库的句柄,否则返回NULL指针。

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结构的地址。调用mysql_real_connect()之前,必须调用mysql_init()来初始化MYSQL结构。
  • host:是主机名或IP地址。如果“host”是NULL或字符串"localhost",连接将被视为与本地主机的连接。
  • user:用户的MySQL登录ID。如果“user”是NULL或空字符串"",用户将被视为当前用户。
  • passwd:用户的密码。如果“passwd”是NULL,仅会对该用户的(拥有1个空密码字段的)用户表中的条目进行匹配检查。
  • db:是数据库名称。如果db为NULL,连接会将默认的数据库设为该值。
  • port:如果“port”不是0,其值将用作TCP/IP连接的端口号。注意,“host”参数决定了连接的类型。
  • unix_socket:如果unix_socket不是NULL,该字符串描述了应使用的套接字或命名管道。注意,“host”参数决定了连接的类型。
  • client_flag:值通常为0

2.2 mysql_query 或 mysql_real_query

该函数用于向数据库发送一条查询命令,并让数据库执行。返回0表示查询成功,否则失败。

int mysql_query(MYSQL *mysql, const char *stmt_str)

或者:

int
mysql_real_query(MYSQL *mysql,
                 const char *stmt_str,
                 unsigned long length)
  • mysql:为通过获取到的mysql操作句柄。
  • stmt_str:表示需要执行的查询语句。
  • length:为查询语句的长度。

上面两个函数的区别在于:

  • mysql_query() 不能用于执行带二进制的语句,也就是参数stmt_str中不能有二进制数据,会被解析成字符。
  • mysql_query查速度稍慢一些,因为需要计算查询语句的长度

2.3 获取结果集mysql_store_result

该函数返回查询成功的结果集,如果失败则返回NULL

MYSQL_RES *mysql_store_result(MYSQL *mysql)

2.4 显示结果集中每行数据

该函数的入参为步骤(3)中返回的结果集。每次调用时,返回结果集中的下一行数据,并将指针向后移动一行,如果没有下一行数据,返回NULL。
可以用mysql_num_fields(result)计算结果集中行的数量,mysql_num_fields(result)可以计算列的数量。假如row为某一行的信息,那么row[0]、row[1]。。。依次该行的各个字段信息。

MYSQL_ROW mysql_fetch_row(MYSQL_RES *result)

3、一个编程示例

这里的环境为linux系统。用到本地数据库名称为:CrashCourse,查询的表名称为products,下面的编程实例中,演示了查询products表中价钱大于30的所有项目。products表格完整内容如下:

#include <stdio.h>
#include <mysql/mysql.h>
#include <iostream>
using namespace std;
 
MYSQL mysql;  //mysql连接
MYSQL_RES* res; //结果集结构体   
MYSQL_ROW row; //char** 二维数组,存放记录  
 
int main()
{	
	// 步骤1: 初始化并连接数据库,获得操作数据库的句柄
	mysql_init(&mysql);    //初始化
	if (!(mysql_real_connect(&mysql, "localhost", "root", "root", "CrashCourse", 0, NULL, 0))) {
		cout << "Couldn't connect to Database!\n : " << mysql_error(&mysql);
		exit(1);
	}
	else {
		printf("Database connection succeeded. Connected...\n\n");
	}
	// 步骤2: 执行查询语句,查询需要的数据(设置编码格式也相当于执行特殊的查询语句)
	mysql_query(&mysql, "set names gbk"); // 设置编码格式
	mysql_query(&mysql, "SELECT * from products where prod_price > 30");
 
	// 步骤3:获取结果集
	res = mysql_store_result(&mysql);
	// 步骤4:显示结果集中每行数据
    int cols = mysql_num_fields(res); // 计算结果集中,列的个数
	while (row = mysql_fetch_row(res)) {
    
    	for (int i = 0; i < cols; ++i) {
      		cout << row[i] << "\t";
    	}
    	cout << endl;
	}
 	// 步骤5:释放结果集合mysql句柄
	mysql_free_result(res);
	mysql_close(&mysql);
 return 0;
 
}

查询结果如下:

总结

到此这篇关于C++连接mysql数据库并读取数据的文章就介绍到这了,更多相关C++连接mysql并读取数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 全面解析C++中的析构函数

    全面解析C++中的析构函数

    这篇文章主要介绍了C++中的析构函数,为C++入门学习中的基础知识,需要的朋友可以参考下
    2016-01-01
  • C++ 数据结构完全二叉树的判断

    C++ 数据结构完全二叉树的判断

    这篇文章主要介绍了C++ 数据结构完全二叉树的判断的相关资料,需要的朋友可以参考下
    2017-06-06
  • strcpy函数实现简示例命分享

    strcpy函数实现简示例命分享

    这篇文章主要介绍了strcpy函数实现简示例命,需要的朋友可以参考下
    2014-03-03
  • 减少OpenCV读取高分辨率图像的时间示例

    减少OpenCV读取高分辨率图像的时间示例

    今天小编就为大家分享一篇减少OpenCV读取高分辨率图像的时间示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12
  • C++ Qt开发之关联容器类使用方法详解

    C++ Qt开发之关联容器类使用方法详解

    当我们谈论编程中的数据结构时,顺序容器是不可忽视的一个重要概念,Qt 中提供了丰富的容器类,用于方便地管理和操作数据,本章我们将主要学习关联容器,主要包括 QMap ,QSet和 QHash,感兴趣的朋友跟着小编一起来学习吧
    2023-12-12
  • C/C++产生随机数函数简单介绍

    C/C++产生随机数函数简单介绍

    这篇文章主要为大家详细介绍了C/C++产生随机数函数的实现方法,如何使用C/C++产生随机数函数,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • 浅谈C语言转义字符和格式控制符

    浅谈C语言转义字符和格式控制符

    下面小编就为大家带来一篇浅谈C语言转义字符和格式控制符。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • VS报错C6011的问题:取消对NULL指针的引用(解决方法)

    VS报错C6011的问题:取消对NULL指针的引用(解决方法)

    这篇文章主要介绍了VS报错C6011的问题:取消对NULL指针的引用(解决方法),C6011:取消对NULL指针的引用,发现是没有进行空指针的判断,解决方案跟随小编一起看看吧
    2024-01-01
  • C++超详细讲解智能指针

    C++超详细讲解智能指针

    为了解决内存泄漏的问题,C++中提出了智能指针。内存泄漏的产生原因有很多,即使我们正确的使用malloc和free关键字也有可能产生内存泄漏,如在malloc和free之间如果存在抛异常,那也会产生内存泄漏。这种问题被称为异常安全
    2022-06-06
  • C语言指针详解

    C语言指针详解

    这篇文章非常详细的讲解了C语言中指针的概念,包含多种方法,多种定义,全面的说明了C语言的特性
    2021-06-06

最新评论