vc6.0运用mysql数据库中的编码所导致的乱码问题(接收和输出的编码必须要一致)
【编译中遇见的问题】
①在用vc 6.0去调用MySQL中的数据时,出现中文乱码
②不明白mysql中的码制
【开始解决问题】
①打开mysql控制台
②开始展示自己
③打开vc 6.0(配置mysql环境在这里我就不哆嗦了)
走起.....在vc 6.0中复制下列代码,进行连接mysql和调用代码如下:
#include <Windows.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <mysql.h>
#include <iostream>
#pragma comment(lib, "ws2_32")
#pragma comment(lib, "libmysql")
using namespace std;
//-------------------------------------调用mysql数据库--------------------------------------。
void xian()
{
//variables like 'char%'
MYSQL mysql;
MYSQL_RES *resultset;
MYSQL_ROW row;
mysql_init(&mysql);
mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "utf8");
cout<<"-------------------------------------------------------"<<endl;
cout<<"| 性命 |"<<" 性别 |"<<" 年龄 |"<<" 诊断结果 |"<<" 处方 |"<<" 费用 |"<<" 时间 |"<<endl;
cout<<"----------------------------------------------------------------"<<endl;
if (!mysql_real_connect(&mysql, "localhost", "root", "123456", "zhaofulu", 3306, NULL, 0))
{
cout <<"\n数据库连接发生错误!";
}
else
{
if(mysql_query(&mysql,"select * from users"))
{
cout << "查询失败";
}
else
{
resultset = mysql_store_result(&mysql);// 获得结果集
if (mysql_num_rows(resultset) != NULL)
{
int numFields = mysql_num_fields(resultset);// 获得表中字段数
while (row = mysql_fetch_row(resultset))
{
int i = 0;
for (i = 0; i < numFields; i++)
{
cout<<"| "<< row[i]<<" ";
}
cout<<"|";
cout<<endl;
cout<<"----------------------------------------------------------------"<<endl;
}
}
else
{
cout<<"\n无查询结果!";
}
cout<<endl;
}
}
}
//---------------------------数据库的连接------------------------------。
int main()
{
const char user[] = "root"; //username
const char pswd[] = "123456"; //password
const char host[] = "localhost"; //or"127.0.0.1"
const char table[] = "zhaofulu"; //database
unsigned int port = 3306; //server port
MYSQL mysql;
mysql_init(&mysql);
if(mysql_real_connect(&mysql,host,user,pswd,table,port,NULL,0))
{
cout<<"connect succeed!"<<endl;
xian();
}
else
{
cout<<"connect failed!"<<endl;
}
mysql_close(&mysql);//断开连接
return 0;
}
③运行vc 6.0
【问题出现】
运行vc 6.0之后的乱码现象截图:
出现乱码现象,没有像mysql中预先输入显示的效果(此时很是纠结)
这时你开始研究代码,开始查资料,得到的结果都一样:编码问题
这时你开始把代码中的一行代码挑了出来(其他都研究懂了,就剩下这一条):
mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "utf8");//必须要在本函数全局定义
你可能会理解这是要让此函数中的所有输入和输出都以编码为utf8的格式进行
【开始解决问题】
① 打开mysql控制台(查看所建的zhaofulu数据库的编码属性)
zhaofulu数据库的编码属性为gbk
②在查看在zhaofulu下的user表的所有属性
所以把代码 mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "utf8");
改成 mysql_options(&mysql, MYSQL_SET_CHARSET_NAME, "latin1");
【再次运行vc 6.0】
【另一种方法】:
在mysql控制台上用命令:set character_set_client=gbk 进行编码修改
vc6.0运用mysql数据库中的编码所导致的乱码问题(接收和输出的编码必须要一致)的更多相关文章
- vc6.0连接mysql数据库
一.MySQL的安装 Mysql的安装去官网下载就可以...最新的是5.7版本.. 二.VC6.0的设置 (1)打开VC6.中选0 工具栏Tools菜单下的Options选项,在Directories ...
- mybatis查询mysql 数据库中 BLOB字段,结果出现乱码
起因 mybatis-plus 通过Mapper 查询数据,映射出来的BLOB字段中的yml数据中文是乱码的 --- DefaultValue: '' Formula: '' HintContent: ...
- 用JDBC把Excel中的数据导入到Mysql数据库中
步骤:0.在Mysql数据库中先建好table 1.从Excel表格读数据 2.用JDBC连接Mysql数据库 3.把读出的数据导入到Mysql数据库的相应表中 其中,步骤0的table我是先在Mys ...
- html页面通过http访问mysql数据库中的内容,实现用户登录的功能
需求: 通过html编写用户登录页面,页面内容包括用户名.密码和登录按钮,点击登录后访问login.php文件,使用按钮默认的submit提交用户名和密码,在login.php中访问mysql数据库, ...
- node 爬虫 --- 将爬取到的数据,保存到 mysql 数据库中
步骤一:安装必要模块 (1)cheerio模块 ,一个类似jQuery的选择器模块,分析HTML利器. (2)request模块,让http请求变的更加简单 (3)mysql模块,node连接mysq ...
- MySQL数据库中delimiter的作用概述
以下的文章主要是向大家描述的是MySQL数据库中delimiter的作用是什么?我们一般都认为这个命令和存储过程关系不大,到底是不是这样的呢?以下的文章将会给你相关的知识,望你会有所收获. 其实就是告 ...
- PHP往mysql数据库中写入中文失败
该类问题解决办法就是 在建立数据库连接之后,将该连接的编码方式改为中文. 代码如下: $linkID=@mysql_connect("localhost","root&q ...
- 从SQLSERVER/MYSQL数据库中随机取一条或者N条记录
从SQLSERVER/MYSQL数据库中随机取一条或者N条记录 很多人都知道使用rand()函数但是怎麽使用可能不是每个人都知道 建立测试表 USE [sss] GO ,NAME ) DEFAULT ...
- 在mysql数据库中制作千万级测试表
在mysql数据库中制作千万级测试表 前言: 最近准备深入的学一下mysql,包括各种引擎的特性.性能优化.分表分库等.为了方便测试性能.分表等工作,就需要先建立一张比较大的数据表.我这里准备先建一张 ...
随机推荐
- SVN与git交互
操作的第一步,就是找到版本库,然后打开,有git的文件夹叫版本库 OrderManagement是版本库 第二步,查看日志,在版本库里内部,空白处右键,选择TortoiseGit--showlo ...
- ajax 选项卡
Ajax其实就是交互式网页应用开发技术包括以下几个方面: 1.XHTML和CSS 2.使用DOM作为动态显示和交互 3.使用XML和XSLT 做数据交互和操作 (这些完全不太懂) 4.使用XMLHtt ...
- sqlserver字段类型
bit 整型 bit数据类型是整型,其值只能是0.1或空值.这种数据类型用于存储只有两种可能值的数据,如Yes 或No.True 或False .On 或Off. 注意:很省空间的一种数据类型, ...
- Lua 自定义函数string.split
function string.split(str, delimiter) if str==nil or str=='' or delimiter==nil then return ...
- iOS、swift、React Native学习常用的社区、论坛
<!----iOS> <!----Swift>*IOS开发常用社区:http://code4app.com/ *IOS开发常用社区:http://www.cocoachina. ...
- Dubbo框架
1. Dubbo是什么? Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案.简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需 ...
- VS2010遇到fatal error C1083: 无法打开预编译头文件:“xxx.pch”: No such file or directory
对C++和VS2010非常不熟悉,但是无奈赶着项目,只能看了点基础就上手,然后就碰到这个问题了. 原因分析: http://bbs.csdn.net/topics/340191697?page=1 编 ...
- Sort merge join、Nested loops、Hash join(三种连接类型)
目前为止,典型的连接类型有3种: Sort merge join(SMJ排序-合并连接):首先生产driving table需要的数据,然后对这些数据按照连接操作关联列进行排序:然后生产probed ...
- oracle 用户与表空间关系
oracle用户与表空间关系用户=商家表=商品表空间=仓库1. 1个商家能有很多商品,1个商品只能属于一个商家2. 1个商品可以放到仓库A,也可以放到仓库B,但不能同时放入A和B3. 仓库不属于任何商 ...
- 【转】无法将notepad++添加到打开方式列表中的解决办法
问题:想要设置notepad++为默认打开方式,却发现在点击browse找到notepad++.exe点击打开后没有在打开方式列表中找到notepad++. 原因:更新程序版本后程序的路径发生了变动. ...