Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/70.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mysql Hibernate在持久化对象时编码错误[UTF-8]_Mysql_Spring_Hibernate_Spring Mvc_C3p0 - Fatal编程技术网

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

Mysql Hibernate在持久化对象时编码错误[UTF-8],mysql,spring,hibernate,spring-mvc,c3p0,Mysql,Spring,Hibernate,Spring Mvc,C3p0,在持久化模型对象时,我面临UTF-8编码问题。土耳其语中的“ı”是一个字母。此外,UTF-8编码中还包含一些其他土耳其字符。当我持久化模型对象时,所有“ı”字符将作为“?”持久化到DB。我正在Ubuntu Linux 64位操作系统上使用MySQL 5.5。另外,我已经将hibernate&c3p0连接编码属性设置为UTF-8。当我调试时,来自客户端的数据为true 这是我的配置,如果有人能帮我,我会很高兴的 提前谢谢 Spring和Hibernate配置 <bean id="s

在持久化模型对象时,我面临UTF-8编码问题。土耳其语中的“ı”是一个字母。此外,UTF-8编码中还包含一些其他土耳其字符。当我持久化模型对象时,所有“ı”字符将作为“”持久化到DB。我正在Ubuntu Linux 64位操作系统上使用MySQL 5.5。另外,我已经将hibernate&c3p0连接编码属性设置为UTF-8。当我调试时,来自客户端的数据为true

这是我的配置,如果有人能帮我,我会很高兴的

提前谢谢


Spring和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>

真的
真的
假的
更新
真的
org.hibernate.dialogue.mysql5innodbdialogue
UTF-8
真的
2.
50
50
2.
2.
300
50

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

尝试在数据源中设置编码

 <bean id="dataSource"
    class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName">
        <value>com.mysql.jdbc.Driver</value>
    </property>
    <property name="url">
        <value>jdbc:mysql://127.0.0.1:3306/databaseName?characterEncoding=UTF-8</value>
    </property>
    <property name="username">
        <value>?</value>
    </property>
</bean>

com.mysql.jdbc.Driver
jdbc:mysql://127.0.0.1:3306/databaseName?characterEncoding=UTF-8
?
另外,您是否确定表单的输入已正确编码?您是否在spring应用程序中使用过滤器?在调试模式下运行应用程序,并在持久化之前检查模型对象的字段

过滤器应放在web.xml文件中:

<filter>
    <filter-name>SetCharacterEncodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF8</param-value>
    </init-param>
    <init-param>
        <param-name>forceEncoding</param-name>
        <param-value>true</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>SetCharacterEncodingFilter</filter-name>
    <url-pattern>*</url-pattern>
</filter-mapping>

SetCharacterEncodingFilter
org.springframework.web.filter.CharacterEncodingFilter
编码
UTF8
强制编码
真的
SetCharacterEncodingFilter
*
如果您已添加

?字符编码=UTF-8

因此(在创建数据库和表之后),您需要重新创建数据库。实际上,在我的例子中,我使用以下方法重新创建了数据库:

创建数据库dbname字符集utf8 COLLATE utf8\u general\u ci

alter database my_database default charset utf8 collate utf8\u general\u ci


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

在尝试了所有Hibernate和MySQL配置之后,该过滤器方法工作正常。谢谢UTF8必须是UTF-8(缺少破折号)。这不适用于postgreSQL数据库。对于postgreSQL数据库,我应该采取哪些步骤?看到我的问题了吗