使用mybatis向MySQL数据库中插入数据Navicat中文乱码问题
问题原因和结果
1.前后对比
2.原因
作为一名程序员,大家都知道出现中文乱码是字符编码不一致的问题,在这个编码的过程中可能出现编码有问题的:IDE、MySQL、Navicat、Java文件编码
排除原因
检查IDE编码和Java文件编码
可以看到在我的项目中使用的IDE中idea是没有什么问题的,所以可以把IDE和JAVA文件的原因排除
检查MySQL数据库原因
- 检查MySQL配置文件my.ini
看到这两个最中要的配置没有问题[mysql] default-character-set=utf8 [mysqld] character-set-server=utf8
- 查看数据库和所建表结构编码,这里直接可以在Navicat中见到可以很简单看到所建数据库和表的编码格式也没有问题
同时使用MySQL-font查看数据库,发现数据中的中文竟然不是乱码,这时就很确定问题一定出现在Navicat上了,也就是可以把MySQL的原因去除
检查Navicat
- 检查连接数据库属性设置
连接属性也没有什么问题 - 客户端和服务端连接字符集设置
分别在MySQL中执行下面命令,得到的结果竟然是不同的show variables like'char%'; show variables like 'collation_%';
所以很明显原因出现在Navicat Navicat Navicat上
解决方案
- 第一种: 把数据库连接属性改为自动
这一种方法Navicat就可已自动把数据库显示成中文 - 第二种: 设置Navicat的字符集和MySQL中一样
首先在Navicat中执行set character_set_client= utf8;set character_set_connection =utf8 ; set character_set_results=utf8 ;
,这时再查看Navicat中的字符集与数据库中的一致了,但是查看表中文依然乱码,重启Navicat之后依然乱码,这是因为Navicat在创建数据库后,字符集就不会变化了,即使用了上述三个命令,重启后会重置
所以正确的步骤是:先设置-再导出-再导入
- 先设置字符集设置成跟MySQL一样
set character_set_client= utf8;set character_set_connection =utf8 ; set character_set_results=utf8 ;
- 备份数据库,导出成一个SQL文件
- 重新建一个数据库,导入执行刚才的SQL文件
这时再去查看数据库中的表字段,就会发现数据库乱中文码问题解决了