码迷,mamicode.com
首页 > 数据库 > 详细

解决hibernate保存数据到mysql中出现乱码问题

时间:2015-02-11 10:33:29      阅读:143      评论:0      收藏:0      [点我收藏+]

标签:

    今天使用hibernate保存数据到mysql中,发现出现乱码问题,经过检查,发现接收到的是正确中文,说明客户端浏览器将中文编码发送到服务器过程中无乱码问题,后来查找资料:

首先要告诉数据库要插入的字符串的字符集,mysql 默认使用的字符集是 latin1。我要保存的字符串是 UTF-8 编码的(字符集是 Unicode),所以包含这个字段的表应该使用 UTF-8 编码。

这里有几种解决办法。

1、在建立数据库的时候指定数据库的字符集编码,这样,这个数据库的所有表都会默认使用数据库的字符集编码。如 create database foo charset utf8;

 

2、在建表的时候指定字符集编码。如 create table foo (id char(20)) charset utf8;

3、指定某一列使用的字符集编码。如create table foo (id char(20) charset utf8);

 

 

 

如果你有需要的话还可以指定字符排序的规则,也就是指定 collation,如 create database foo charset utf8 collate utf8_general_ci;,同样也可以指定单独的表、列使用的 collation 规则。

然后在使用 jdbc 连接数据库的时候要告知 jdbc 使用什么字符集编码来跟服务器通信。很简单,只需要在 jdbc 指定数据库路径时做一点修改就可以了。比如,jdbc:mysql://localhost/test?useUnicode=true&characterEncoding=utf8。注意如果在 XML 文件里面的话 “&” 要改成 “&amp”。

完整的写法:jdbc:mysql://localhost/test?useUnicode=true&characterEncoding=UTF-8

在hibernate的配置文件里面修改代码如下:

<property name="connection.url">  

           jdbc:mysql://127.0.0.1:3306/hello?useUnicode=true&characterEncoding=UTF-8  

</property> 

解决hibernate保存数据到mysql中出现乱码问题

标签:

原文地址:http://www.cnblogs.com/lomomiao/p/4285397.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!