-
查看MySQL数据库编码
* SHOW VARIABLES LIKE ‘char%’; -
编码解释
* character_set_client:MySQL使用该编码来解读客户端发送过来的数据,例如该编码为UTF8,那么如果客户端发送过来的数据不是UTF8,那么就会出现乱码
* character_set_results:MySQL会把数据转换成该编码后,再发送给客户端,例如该编码为UTF8,那么如果客户端不使用UTF8来解读,那么就会出现乱码
其它编码只要支持中文即可,也就是说不能使用latin1 -
控制台乱码问题
* 插入或修改时出现乱码:
> 这时因为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,还需要再次设置变量。 -
指定默认编码(一劳永逸解决办法)
在my.ini(MySQL安装目录里)中设置character-set-server=utf8即可,它可以修改三个变量:client、results、connection。
注:
当我们用可视化工具操作数据库时(比如SQLyog),工具会自动帮我们解决编码问题,不用我们关注,即数据库的编码问题只在WINDOWS的CMD控制台中才存在!
character_set_client=utf8:无论客户端发送的是什么编码的数据,mysql都当成是utf8的数据
> 若客户端发送的是GBK,服务器总会当成utf8对待,最后就是乱码
处理问题的手段有两种:
> 让客户端发送utf8的数据(行不通)
> 把 character_set_client = utf8修改为=gbk
set character_set_client=gbk; -->只在当前窗口内有效,也就是说,关闭窗口后,再打开,又回到utf8
character_set_results = utf8 :把数据用什么编码发送给客户端
> 若服务器发送给客户端的是utf8的数据
> 客户端会把它当成gbk,因为windows cmd,只能显示gbk
> 总结:必然乱码!
处理问题的手段有两种:
> 让服务器发送gbk的数据:set character_set_results=gbk
> 让cmd使用utf8来解读(行不通)