vs如何读取mysql中的数据并解决中文乱码问题

作者:獜洛橙 时间:2024-01-19 08:14:01 

一、在vs中新建一个工程,然后新建一个源文件

vs如何读取mysql中的数据并解决中文乱码问题

二、右击上述图片中的mysql_test工程名,然后在最下方找到属性,并点击

vs如何读取mysql中的数据并解决中文乱码问题

三、点击VC++目录,在包含目录中添加mysql的文件路径,一般情况下的mysql的默认安装路径都是在C盘的Program Files下的,找到include路径,然后点击确定

vs如何读取mysql中的数据并解决中文乱码问题

四、在C/C++中的常规选项中,找到附加包含目录,同时也将mysql的include路径包含进去 

vs如何读取mysql中的数据并解决中文乱码问题

vs如何读取mysql中的数据并解决中文乱码问题

五、在属性页中选择链接器的常规选项,在里面找到附加库目录,然后添加mysql的lib路径

vs如何读取mysql中的数据并解决中文乱码问题

六、 在链接器的输入选项中,找到附加依赖项,然后直接写上libmysql.lib

vs如何读取mysql中的数据并解决中文乱码问题

七、最后再mysql的bin目录中,将libmysql.dll复制一份到c:\windows\system32路径下即可。 八、随便找一段代码测试,这里用的是其他人的博客里面的代码,当然有些许是修改了的,这里会作相应介绍。

mysql测试代码如下:

create database test;
use test;
create table test_1(name varchar(128),age int);
insert into test_1 values('獜洛橙',18);

vs测试代码如下(要注意修改mysql用户名和密码为自己的,同时还有database的名字和里面的表的名字,我这里用户名是root,密码是123456,database是上面mysql测试代码中的test,表名是test_1):

#include <stdio.h>
#include <WinSock.h>
#include <Windows.h>
#include <mysql.h>
#include<iostream>
using namespace std;

MYSQL mysql;  //mysql连接
MYSQL_RES* res; //一个结果集结构体  
MYSQL_ROW row; //char** 二维数组,存放一条条记录  

const char DataBase_UserName[] = "root";    //数据库用户名username
const char DataBase_Password[] = "123456";   //数据库密码,填自己的密码
const char DataBase_Host[] = "localhost";  //数据库连接地址
//注意有时候使用主机ip会报错,此时可以将ip改为localhost
const char DataBase_Name[] = "test";  //database name
unsigned int DataBase_Port = 3306;            //server port

bool ConnectDatabase(); //函数申明
void FreeConnect();   //释放资源

wchar_t* Utf8_2_Unicode(char* row_i)
{
int len = MultiByteToWideChar(CP_UTF8, 0, row_i, strlen(row_i), NULL, 0);
wchar_t* wszStr = new wchar_t[len + 1];
MultiByteToWideChar(CP_UTF8, 0, row_i, strlen(row_i), wszStr, len);
wszStr[len] = '\0';
return wszStr;
}

void main()
{
setlocale(LC_ALL, "chs");
ConnectDatabase();//连接数据库
//查询数据
mysql_query(&mysql, "SELECT * from test_1");
//获取结果集
res = mysql_store_result(&mysql);
//显示数据
//给ROW赋值,判断ROW是否为空,不为空就打印数据。
while (row = mysql_fetch_row(res))
{
wchar_t* m1 = Utf8_2_Unicode(row[0]);
wchar_t* m2 = Utf8_2_Unicode(row[1]);
wprintf_s(L"%s  %s", m1,m2);
}
FreeConnect();
getchar();
}

bool ConnectDatabase()
{
//初始化mysql
mysql_init(&mysql);   //连接mysql,数据库
//中间分别是主机,用户名,密码,数据库名,端口号(可以写默认0或者3306等),可以先写成参数再传进去
if (!(mysql_real_connect(&mysql, DataBase_Host, DataBase_UserName, DataBase_Password, DataBase_Name, DataBase_Port, NULL, 0))) {
printf("Error connecting to database:%s\n", mysql_error(&mysql));
return false;
}
else {
MessageBoxA(NULL, "连接MYSQL数据成功!", "消息", MB_OK);
printf("Connected...\n");
return true;
}
}
//释放资源
void FreeConnect() {
mysql_close(&mysql);
}

九、如果成功即显示如下的提示信息框

vs如何读取mysql中的数据并解决中文乱码问题

十、打印结果(成功显示)

vs如何读取mysql中的数据并解决中文乱码问题

来源:https://blog.csdn.net/weixin_54627824/article/details/125991264

标签:vs,读取,mysql,数据
0
投稿

猜你喜欢

  • python3操作mysql数据库的方法

    2023-07-28 15:48:27
  • python 协程并发数控制

    2023-09-20 01:07:10
  • Java访问数据库实例详解

    2024-01-23 00:12:20
  • Python turtle画图库&&画姓名实例

    2021-07-03 09:02:02
  • Python Excel数据处理之xlrd/xlwt/xlutils模块详解

    2022-03-28 16:45:53
  • PyTorch 普通卷积和空洞卷积实例

    2021-01-06 16:42:57
  • Django实战之用户认证(初始配置)

    2022-08-17 22:15:02
  • 通过格式良好的SQL提高效率和准确性

    2024-01-21 21:16:27
  • python中import与from方法总结(推荐)

    2021-12-19 12:31:06
  • SHA256算法 asp源码

    2009-08-28 13:01:00
  • python使用threading获取线程函数返回值的实现方法

    2023-10-28 09:34:21
  • python opencv把一张图片嵌入(叠加)到另一张图片上的实现代码

    2021-08-11 12:52:30
  • python3实现读取chrome浏览器cookie

    2023-10-18 13:18:44
  • Python神经网络TensorFlow基于CNN卷积识别手写数字

    2022-06-18 20:23:00
  • python 采集中文乱码问题的完美解决方法

    2021-05-13 13:46:58
  • 从JavaScript的函数重名看其初始化方式

    2023-07-16 22:00:12
  • 浅谈在django中使用filter()(即对QuerySet操作)时踩的坑

    2022-05-03 10:24:49
  • Python实现变声器功能(萝莉音御姐音)

    2023-04-12 23:04:16
  • 如何通过python实现IOU计算代码实例

    2021-07-09 02:06:44
  • Python写的Socks5协议代理服务器

    2022-03-16 21:22:44
  • asp之家 网络编程 m.aspxhome.com