解决cmd客户端插入包含中文数据乱码

时间:2023-01-06 13:02:32

       在Navicat客户端或者SQLyog客户端中插入中文数据到数据库没有乱码,但是在cmd中插入数据后,再在cmd命令行查询发现乱码了。

通过输入语句:

show variables like 'character%';

     
查询数据库当前的编码集。

解决cmd客户端插入包含中文数据乱码

从上图中可以看到 MySQL 有六处使用了字符集,分别为:client 、connection、database、results、server 、system。其中与服务器端相关:database、server、system(永远无法修改,就是utf-8);与客户端相关:connection、client、results 。


client 为客户端使用的字符集
connection 为连接数据库设置的字符集,如果连接数据库的字符集没有指定,则按照服务器默认的字符集设置
database 为数据库服务器中某个数据库使用的字符集设定,若建库时没有指定,则使用数据库默认的字符集
server 为服务器安装时指定的默认的字符集
results 为数据库返回客户端所指定的字符集,若客户端没有设置,则使用服务器默认的字符集
system 为数据库系统使用的字符集设定

该问题出现在cmd客户端,所以需要修改connection、results、client的编码集。因为cmd采用gbk编码,而数据库编码采用    utf-8,所以需要改变编码。

在 MySQL 的安装目录下有一个 my.ini 配置文件,通过修改这个配置文件可以一劳永逸的解决乱码问题。在这个配置文件中 [mysql] 与客户端配置相关,[mysqld] 与服务器配置相关。默认配置如下:

[client]

port=3306

default-character-set=utf8

[mysql]

default-character-set=utf8

character-set-server=utf8

将以上编码格式utf8改成gbk编码,然后重启MySQL服务即可。

-------------------------------------------------------------------------------------------------------------------

PS:mysql服务重启步骤:在window搜索框输入services.msc;在服务中找到MySQL服务,点击重启;

或者:在cmd命令行中输入net stop mysql,按回车;再输入net start mysql回车即可。