vs如何读取mysql中的数据并解决中文乱码问题
来源:脚本之家
时间:2022-12-29 11:59:04 209浏览 收藏
怎么入门数据库编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《vs如何读取mysql中的数据并解决中文乱码问题》,涉及到MySQL、数据、vs读取,有需要的可以收藏一下
一、在vs中新建一个工程,然后新建一个源文件
二、右击上述图片中的mysql_test工程名,然后在最下方找到属性,并点击
三、点击VC++目录,在包含目录中添加mysql的文件路径,一般情况下的mysql的默认安装路径都是在C盘的Program Files下的,找到include路径,然后点击确定
四、在C/C++中的常规选项中,找到附加包含目录,同时也将mysql的include路径包含进去
五、在属性页中选择链接器的常规选项,在里面找到附加库目录,然后添加mysql的lib路径
六、 在链接器的输入选项中,找到附加依赖项,然后直接写上libmysql.lib
七、最后再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#include #include #include #include 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中的数据并解决中文乱码问题》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
-
184 收藏
-
237 收藏
-
210 收藏
-
192 收藏
-
364 收藏
-
373 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习