乱码问题其实归根接地就是两端的字符集不统一。
解决思路也有两种:
1. 修改两端字符集统一。
2. 通过代码进行转码,从而达到字符集的统一。
在Mysql中,默认使用的字符集是latin1(拉丁文),所以我会在建立数据库时,将数据库默认编码设置为utf-8.
对于乱码的解决思路,
1. 查看在插入数据库前,数据的实际内容,如果已经是乱码了,那么就是代码中有错误,和数据库是无关的。
2. 查看数据库中的数据,如果是乱码,那么一般情况下,就是由于数据库和输入端的字符集不统一导致的。
3. 检查数据库字符集,和java的数据集
4. 修改一方
在配置文件中设置(xml)
true UTF-8
在连接字符串设置
properties: url=jdbc:mysql://localhost:3306/msms?useUnicode=true&characterEncoding=utf-8 xml:
mysql字符集设置
查看字符集 show variables like ‘character%’ 设置字符集 set character_set_database = utf8; 修改表的字符集 ALTER TABLE hibernate1.news CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci; 查看表信息 SELECT * FROM information_schema.tables WHERE table_schema = ‘test_utf8’ ORDER BY table_name DESC;