美文网首页
关于Navicat和MYSQL字符集不统一出现的中文乱码问题

关于Navicat和MYSQL字符集不统一出现的中文乱码问题

作者: 烛火下的乌托邦丶 | 来源:发表于2018-04-28 13:22 被阅读0次

    在此之前,服务器上安装好MySQL之后就立马重新配置了字符集为utf8,之后用Navicat进行数据导入,发现中文的字符导入之后全是乱码,然后查论坛很

    快通过以下方式解决了:建立连接时编码选择UTF-8,把使用MYSQL字符集之前的勾勾去掉。

    数据库的属性设置为:

    OK,Navicat里的中文字符正常了。于是 ,开心的进行数据导入,一切感觉完美~

    接下来我在命令行采用最简单的mysqldump方法进行备份,备份成功,因为都是测试数据,我顺手打开备份好的文件一看,又是乱码!之后命令行直接进到数据库查询,

    果然查询结果也是乱码!我用命令行建了一个测试表,插入中文数据,查表,显示正确;Navicat查表,乱码。这是什么情况~明明两边都是UTF-8

    编码方式。

    内心一万只羊驼奔过...

    OK 我们现在来一步步排查问题:

    首先,打开/etc/my.cnf 文件查看是否字符集配置正确,果然,在[mysqld] 下错写成了default-character-set=utf8

    正确的配置方式:

    先备份一下my.cnf文件,然后 vim /etc/my.cnf 插入以下几行

    [client]

    default-character-set=utf8

    [mysqld]

    character-set-server=utf8#注意这行不要写成 default-character-set=utf8

    [mysql]

    no-auto-rehash

    保存之后service mysqld restart启动成功  ,进行之前的数据测试,乱码问题依然存在。能两边的字符集真的不一样呢?

    查了一些资料才知道:只要涉及到文字的地方,就会存在字符集和编码方式。对于MySQL数据库系统而言,用户从MySQL client端敲入一条sql语句,通过TCP/IP传递给

    MySQL server进程,到最终存入server端的文件,每个环节都涉及到字符存储。涉及到字符存储的地方,就涉及到字符集编码。

    我们就用 show variables like'char%';和 showvariables like 'collation_%';来查看一下:

    分别在MYSQL、Navicat中运行命令;

    两边有些字符集和校对的系统变量是不同的。

    至此,我找到了问题的关键。

    最后我们去解决问题,我有两种方法:

    ①我们以MySQL配置为准。在Navicat 中运行以下命令:

    setcharacter_set_client= utf8;

    setcharacter_set_connection =utf8 ;

    setcharacter_set_results=utf8 ;

    相关文章

      网友评论

          本文标题:关于Navicat和MYSQL字符集不统一出现的中文乱码问题

          本文链接:https://www.haomeiwen.com/subject/tofulftx.html