vs如何读取mysql中的数据并解决中文乱码问题
一、在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 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数据内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 vs如何读取mysql中的数据并解决中文乱码问题
相关文章
- 软件无需安装,使用MySQL软件(免安装的mysql)
- MySQL 中文界面使用指南(mysql中文界面)
- 数据MySQL查询小时数据的实践指南(mysql获取小时)
- 妙用MySQL:存储中文数据的好办法(mysql数据库存中文)
- MySQL实现快速复制(mysql快速复制)
- 导入MySQL数据表:简单而快速的方法(导入mysql数据表)
- 远程登录MySQL:解决方案(远程登录mysql)
- MySQL字段去除空格的简单方法(mysql字段去掉空格)
- 导入无法导入MySQL中文数据分析(mysql无法中文)
- 重新安装:Linux系统完全卸载MySQL(linux完全卸载mysql)
- MySQL查看表内容:一步一步指南(mysql查看表的内容)
- MySQL 模糊查询:解决中文检索问题(mysql模糊查询中文)
- 类型理解MySQL中的二进制数据类型(mysql二进制数据)
- MySQL:何种类型的数据库?(mysql是什么型数据库)
- MySQL复制字段的实现方法(mysql复制字段)
- 中文MySQL无法插入中文记录(mysql不能插入)
- MySQL解决中文乱码的方法(mysql保存中文乱码)
- 如何在MySQL中查询中文?(mysql查询中文)
- 如何在MySQL控制台中输入中文(mysql 控制台 中文)
- MySQL数据库支持中文显示(mysql数据库显示中文)
- 25字中文文章标题MySQL高级操作深入了解G系列函数的使用方法(mysql中 g如何使用)
- MySQL中文参数让你进行更高效的查询(c mysql 中文参数)
- 比较C和MySQL 略显不均之下的选择(c++ mysql vs)
- 1500年的MySQL,穿越岁月的不朽延续(1500与mysql)
- 25字中文文章标题MySQL不在其中为什么不要再使用MySQL数据库(mysql不存在于)
- MySQL无法进行中文查询(mysql不支持汉子查询)
- MySQL表中文命名不支持(mysql不支持中文命名)
- MySQL无法存储中文字符(mysql不能存汉子)