持久化对象时,Hibernate编码错误[UTF-8]

时间:2012-08-01 11:18:55

标签: mysql spring hibernate spring-mvc c3p0

我在使用模型对象时遇到UTF-8编码问题。在土耳其语'ı'是一封信。还有一些其他土耳其字符包含在UTF-8编码中。当我保留我的模型对象时,所有'ı'字符都会以“”的形式保存到数据库中。我在Ubuntu Linux 64位操作系统上使用 MySQL 5.5 。我已经设置了hibernate& c3p0连接编码属性也是UTF-8。当我调试时,来自客户端的数据是真的。

这是我的配置,如果有人可以帮助我,我会很高兴。

提前致谢。


春天& Hibernate配置

    <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource"><ref local="dataSource"/></property>
        <property name="packagesToScan" value="com.tk.dms.model" />
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.use_sql_comments">true</prop>
                <prop key="hibernate.format_sql">false</prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
                <prop key="hibernate.generate_statistics">true</prop>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
                <prop key="hibernate.connection.characterEncoding">UTF-8</prop>
                <prop key="hibernate.connection.useUnicode">true</prop>
                <!-- c3p0 properties -->
                <prop key="hibernate.c3p0.min_size">2</prop>
                <prop key="hibernate.c3p0.max_size">50</prop>
                <prop key="hibernate.c3p0.maxPoolSize">50</prop>
                <prop key="hibernate.c3p0.minPoolSize">2</prop>
                <prop key="hibernate.c3p0.initialPoolSize">2</prop>
                <prop key="hibernate.c3p0.timeout">300</prop>
                <prop key="hibernate.c3p0.max_statements">50</prop>                
            </props>
        </property>
    </bean>

2 个答案:

答案 0 :(得分:1)

如果您已添加

  

?的characterEncoding = UTF-8

因此,

连接字符串的参数(在创建了db和表之后),您需要重新创建数据库。实际上在我的情况下,我重新创建了我的数据库:

  

CREATE DATABASE dbname CHARACTER SET utf8 COLLATE utf8_general_ci;

OR

  

alter database my_database default charset utf8 collat​​e utf8_general_ci;

请注意,我使用的是西里尔字符串。

答案 1 :(得分:0)

检查bean中存储的数据是什么。您的bean是如何填充的?是通过用户输入吗?如果是,那么您必须将该页面中的编码写为UTF-8并将您的请求和响应参数更改为UTF-8