经常我们会碰到数据乱码的问题,有页面乱码,java运行时变量里的数据乱码,数据库表数据乱码。我今天主要说说我在工作中遇到的数据库表数据乱码问题怎么解决。
当我们表里数据保存后发现乱码,首先我们要确定数据的来源以及中间处理层的字符集编码是不是一致,比如我们用java从文件中读取一段utf-8的文字然后保存到数据库中时,首先我们得用utf-8编码读取并用utf-8保存到数据库中。也就是说java应用层和数据库的编码必须一致才不会出现乱码。
应用层的编码我们暂时不说,我主要分享一下mysql数据库中的乱码如何解决,关于乱码为什么会出现或者说原理我也讲不通,给个链接,大家自己看,乱码是怎么形成的?
我们出现在数据库乱码时,先确定是不是java层就乱码了,如果不是,那肯定是数据到数据库层才乱码的。所以我们需要再次确认数据库层的每个过程都是utf-8(我们以utf-8编码为例,你用gbk也是可以的),下面就看看怎么看数据库每个有可能造成乱码的地方:
一、MySQL全局编码配置
mysql的全局变量可以通过命令来修改,也可以在my.cnf(windows下配置文件为my.ini)中配置,内容如下:
[mysqld]
character-set-server=utf8
collation_server=utf8_general_ci
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
如上my.cnf的编码配置,如果我们java读取的文件是utf-8