关于Navicat和MYSQL字符集不统一出现的中文乱码问题
来源:互联网 发布:黑客数据交易平台 编辑:程序博客网 时间:2024/05/17 01:50
最近遇到一串关于MySQL中文乱码的问题,问题背景是这样的:
在此之前,服务器上安装好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 ;
再查看字符集,两边就一致了。进行测试,乱码问题解决。
②保证MySQL字符集配置正确的前提下,在navicat的连接属性中勾选使用MYSQL字符集。
最后才发现自己把自己坑了。
不管怎样,最后问题解决了,又可以愉快的工作了。
以下是我参考的一些文章:
http://www.douban.com/note/268110263/?type=like
http://www.linuxidc.com/Linux/2015-04/116550.htm
- 关于Navicat和MYSQL字符集不统一出现的中文乱码问题
- 关于Navicat和MYSQL字符集不统一出现的中文乱码问题
- 【MySQL for Mac】navicat for mysql中文乱码问题——MySQL在Mac的字符集设置
- MySQL的字符集以及中文乱码问题
- navicat导入mysql的sql文件出现中文乱码
- 关于MySQL中文字符出现乱码的问题
- 关于mysql varchar字段 存储中文出现乱码的问题
- 关于xcode下访问mysql出现中文乱码的问题
- 关于java连接mysql出现中文乱码的问题
- navicat和doc下查看mysql的字符集不一样问题
- 就Navicat for MySQL出现的乱码问题进行讨论
- (乱码问题大都是由于工具之间的编码格式不统一)Oracle字符集的查看查询和Oracle字符集的设置修改
- Navicat for MySQL中文乱码问题
- Navicat for mysql 中文乱码问题
- Navicat for mysql 显示中文乱码问题
- mybatis + mysql + mac navicat 中文乱码问题
- 关于php编程中出现乱码的字符集的问题
- Java MySQL 中文出现乱码的问题
- HashMap源码剖析
- 欢迎使用CSDN-markdown编辑器
- How does deep residual learning work?
- python重温设计模式===>行为型
- spring学习(一)— spring 概念
- 关于Navicat和MYSQL字符集不统一出现的中文乱码问题
- git服务器搭建
- html之file标签 --- 图片上传前预览 -- FileReader
- jenkins定时自动备份数据库
- C++拾趣——类构造函数的隐式转换
- asp数组使用
- 实现点击上传文件将文件名称显示在text中
- Linux、ubuntu14.04下源码安装node.js、express
- linux中find查找指定时间段的文件并grep查找内容