当前位置: 首页 > article >正文

在VS2022中用C++连接MySQL数据库读取数据库乱码问题

1.正确安装mysql

安装之后的配置文件

2.在VS2022中进行相关配置

(1)右键项目,打开属性

注意是右键项目,不是.cpp文件

(2)配置属性-> VC++目录  -> 包含目录 ->添加头文件路径(如图)

(3)配置属性-> VC++目录  -> 库目录 ->添加动态库路径(如图)

(4)在  链接器 -> 输入 ->附加依赖项 中输入libmysql.lib

(5)  将了lib文件夹中的libmysql.dll文件  复制到C:\Windows\System32

接下来 就可以可以运行代码了

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

using namespace std;

int main() {
	MYSQL* conn;   // MySQL连接
	MYSQL_RES* res;   // MySQL查询结果
	MYSQL_ROW row;   // MySQL行

	// std::locale::global(std::locale("en_US.UTF-8"));  // 将程序的全局区域设置为 UTF-8 区域,

	//连接数据库的信息
	const char* server = "localhost";
	const char* user = "ml";
	const char* password = "123456";
	const char* datebase = "testdb";

	// 初始化MySQL连接
	conn = mysql_init(NULL);
	// 连接数据库
	if (conn == NULL) {
		cerr << "MYSQL数据库初始化失败" << endl;
		return 1;
	}

	if (mysql_real_connect(conn, server, user, password, datebase, 0, NULL, 0) == NULL) {
		cerr << "MYSQL数据库连接失败:" << mysql_error(conn) << endl;
		return 1;
	}


	// 查询数据库
	mysql_query(conn, "set names utf8");
	if (mysql_query(conn, "SELECT * FROM tb_user")) {

		cerr << "查询失败" << mysql_error(conn) << endl;
		return 1;
	}

	// 获取查询结果
	res = mysql_use_result(conn);
	//输出结果
	/*while ((row = mysql_fetch_row(res)) != NULL) {
		cout << row[0] << " " << row[1] << endl;
	}*/

	// 逐行输出结果
	while ((row = mysql_fetch_row(res)) != NULL) {
		// 输出当前行的所有列数据
		for (int i = 0; i < mysql_num_fields(res); ++i) {
			if (i > 0) {
				cout << " ";  // 列之间用空格分隔
			}
			if (row[i] == NULL) {
				cout << "NULL";  // 处理 NULL 数据
			}
			else {
				cout << row[i];
			}
		}
		cout << endl;  // 行尾输出换行符
	}

	// 释放结果
	mysql_free_result(res);
	// 关闭连接
	mysql_close(conn);

	return 0;
}

3.中文乱码

运行之后,中文乱码

这是因为:数据库编码格式为utf8mb4,但是黑窗口gbk,

所以要进行全局编码设置

问题解决!!


http://www.kler.cn/a/505998.html

相关文章:

  • 《AI赋能鸿蒙Next,打造极致沉浸感游戏》
  • 响应式 Vue 页面布局组件-Element Plus
  • Pytorch基础教程:从零实现手写数字分类
  • 蓝桥杯_B组_省赛_2022(用作博主自己学习)
  • Unity3D手机游戏发热发烫优化指南与技巧详解
  • linux mysql 备份
  • RK3568 Android11 锁屏界面屏蔽下拉状态栏
  • SIBR详细介绍:基于图像的渲染系统及3DGS实例展示【3DGS实验复现】
  • 金仓Kingbase客户端KStudio报OOM:Java heap space socketTimeout
  • Subprocess check_output returned non-zero exit status 1
  • APKLeaks:一款针对APK文件的数据收集与分析工具
  • Git 合并和 Git 变基有什么区别?
  • 利用Redis实现付款倒计时
  • Chapter5.4 Loading and saving model weights in PyTorch
  • 【机器学习实战入门项目】基于机器学习的鸢尾花分类项目
  • C++:工具VSCode的编译和调试文件内容:
  • Python爬虫:从入门到实践
  • 路由环路的产生原因与解决方法(1)
  • 在Android 15的设备上关闭edge-to-edge功能
  • uniapp 页面铺满屏幕
  • STM32 FreeRTOS 信号量
  • 使用docker-compose安装ELK(elasticsearch,logstash,kibana)并简单使用
  • Web基础-分层解耦-IOC与DI入门(具体的是实现步骤)
  • 遥感原理及图像处理
  • 向量数据库Milvus详解
  • day_2_排序算法和树