码迷,mamicode.com
首页 > 数据库 > 详细

MySQL数据库在WIN系统CMD下的编码问题

时间:2016-11-03 21:05:50      阅读:230      评论:0      收藏:0      [点我收藏+]

标签:har   like   cmd   默认   bsp   ble   乱码问题   ini   mysql数据库   

MySQL数据库在WIN系统CMD下的编码问题

1. 查看MySQL数据库编码
  * SHOW VARIABLES LIKE ‘char%‘;

2. 编码解释
  * character_set_client:MySQL使用该编码来解读客户端发送过来的数据,例如该编码为UTF8,那么如果客户端发送过来的数据不是UTF8,那么就会出现乱码
  * character_set_results:MySQL会把数据转换成该编码后,再发送给客户端,例如该编码为UTF8,那么如果客户端不使用UTF8来解读,那么就会出现乱码
  其它编码只要支持中文即可,也就是说不能使用latin1

3. 控制台乱码问题
  * 插入或修改时出现乱码:
    > 这时因为cmd下默认使用GBK,而character_set_client不是GBK的原因。我们只需让这两个编码相同即可。
    > 因为修改cmd的编码不方便,所以我们去设置character_set_client为GBK即可。
  * 查询出的数据为乱码:
    > 这是因为character_set_results不是GBK,而cmd默认使用GBK的原因。我们只需让这两个编码相同即可。
    > 因为修改cmd的编码不方便,所以我们去设置character_set_results为GBK即可。
  * 设置变量的语句:
    > set character_set_client=gbk;
    > set character_set_results=gbk;
  注意:设置变量只对当前连接有效,当退出窗口后,再次登录mysql,还需要再次设置变量。

4. 指定默认编码(一劳永逸解决办法)
  在my.ini(MySQL安装目录里)中设置character-set-server=utf8即可,它可以修改三个变量:client、results、connection。
注:

  当我们用可视化工具操作数据库时(比如SQLyog),工具会自动帮我们解决编码问题,不用我们关注,即数据库的编码问题只在WINDOWS的CMD控制台中才存在!

    

 

 

MySQL数据库在WIN系统CMD下的编码问题

标签:har   like   cmd   默认   bsp   ble   乱码问题   ini   mysql数据库   

原文地址:http://www.cnblogs.com/fengmingyue/p/6028147.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!