如果持久化的类中有包括了汉字的String对象,那么对应到数据库中汉字的部分就会是乱码。这主要是由于MySQL数据表的字符集与我们当前使用的本地字符集不相同造成的。
如果是windows系统,那么系统默认的本地字符集是gb2312,为了让数据表也使用gb2312字符集,我们要这样编写创建数据表的SQL语句:
CREATE TABLE TEST
{
...
...
...
}default character set gb2312;然后在hibernate.cfg.xml中加上:
<property name="connection.characterEncoding">gb2312</property>
如果是linux系统,则只需要把上面的gb2312改成UTF8即可。
本文将介绍如何在MySQL数据库中解决汉字乱码问题,包括如何在创建数据表时指定字符集为gb2312或UTF8,并通过hibernate.cfg.xml配置编码方式。
881

被折叠的 条评论
为什么被折叠?



