使用Navicat连接Mysql数据库中文乱码问题

问题原因和结果

1.前后对比

未解决 解决后

2.原因
作为一名程序员,大家都知道出现中文乱码是字符编码不一致的问题,在这个编码的过程中可能出现编码有问题的:IDEMySQLNavicatJava文件编码

排除原因

检查IDE编码和Java文件编码

在这里插入图片描述
在这里插入图片描述
可以看到在我的项目中使用的IDE中idea是没有什么问题的,所以可以把IDE和JAVA文件的原因排除

检查MySQL数据库原因

  1. 检查MySQL配置文件my.ini
    [mysql]
    default-character-set=utf8
    [mysqld]
    character-set-server=utf8
    
    看到这两个最中要的配置没有问题
  2. 查看数据库和所建表结构编码,这里直接可以在Navicat中见到可以很简单看到所建数据库和表的编码格式也没有问题

在这里插入图片描述
在这里插入图片描述
同时使用MySQL-font查看数据库,发现数据中的中文竟然不是乱码,这时就很确定问题一定出现在Navicat上了,也就是可以把MySQL的原因去除
在这里插入图片描述

检查Navicat

  1. 检查连接数据库属性设置在这里插入图片描述
    连接属性也没有什么问题
  2. 客户端和服务端连接字符集设置
    分别在MySQL中执行下面命令,得到的结果竟然是不同的
    show variables like'char%';
    show variables like 'collation_%';
    

在这里插入图片描述
在这里插入图片描述
所以很明显原因出现在Navicat Navicat Navicat

解决方案

  1. 第一种: 把数据库连接属性改为自动
    这一种方法Navicat就可已自动把数据库显示成中文
  2. 第二种: 设置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文件
    这时再去查看数据库中的表字段,就会发现数据库乱中文码问题解决了
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值