在持久化我的模型对象时,我面临着 UTF-8 编码问题。在土耳其语中,“ ı ”是一个字母。UTF-8 编码中还包含一些其他土耳其语字符。当我坚持我的模型对象时,所有 ' '字符都坚持为 ' ? ' 到数据库。我在 Ubuntu Linux 64-bit OS 上使用 MySQL 5.5。此外,我也已经将休眠和 c3p0 连接编码属性设置为 UTF-8。当我调试时,来自客户端的数据是真实的。
这是我的配置,如果有人可以帮助我,我会很高兴。
提前致谢。
春季和休眠配置
<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>