当前位置:   article > 正文

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

navicat中午乱码

问题原因和结果

1.前后对比

未解决 解决后

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

排除原因

检查IDE编码和Java文件编码

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

检查MySQL数据库原因

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

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

检查Navicat

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

在这里插入图片描述
在这里插入图片描述
所以很明显原因出现在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文件
    这时再去查看数据库中的表字段,就会发现数据库乱中文码问题解决了
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Cpp五条/article/detail/303061
推荐阅读
相关标签
  

闽ICP备14008679号