欢迎投稿

今日深度:

Hibernate乱码问题解决

Hibernate乱码问题解决


乱码问题其实归根接地就是两端的字符集不统一。
解决思路也有两种:
1. 修改两端字符集统一。
2. 通过代码进行转码,从而达到字符集的统一。

在Mysql中,默认使用的字符集是latin1(拉丁文),所以我会在建立数据库时,将数据库默认编码设置为utf-8.

对于乱码的解决思路,
1. 查看在插入数据库前,数据的实际内容,如果已经是乱码了,那么就是代码中有错误,和数据库是无关的。
2. 查看数据库中的数据,如果是乱码,那么一般情况下,就是由于数据库和输入端的字符集不统一导致的。
3. 检查数据库字符集,和java的数据集
4. 修改一方

在配置文件中设置(xml)

<property name="connection.useUnicode">true</property> 
<property name="connection.characterEncoding">UTF-8</property>

在连接字符串设置

properties:
url=jdbc:mysql://localhost:3306/msms?useUnicode=true&characterEncoding=utf-8
xml:
<property name="url" value="jdbc:mysql://localhost:3306/test?useUnicode=true&amp;characterEncoding=utf-8"></property>

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;

www.htsjk.Com true http://www.htsjk.com/sybase/19621.html NewsArticle Hibernate乱码问题解决 乱码问题其实归根接地就是两端的字符集不统一。 解决思路也有两种: 1. 修改两端字符集统一。 2. 通过代码进行转码,从而达到字符集的统一。 在Mysql中,默认使...
评论暂时关闭