首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过Hibernate创建架构时使用UTF-8的问题

通过Hibernate创建架构时使用UTF-8的问题
EN

Stack Overflow用户
提问于 2009-07-23 16:09:13
回答 2查看 5.8K关注 0票数 5

这是我的hibernate.hbm.xml,我使用MySQL

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>

        <property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/dbName?autoReconnect=true&amp;useUnicode=true&amp;characterEncoding=UTF-8</property>
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.connection.password">******</property>

        <property name="hbm2ddl.auto">update</property>
        <property name="hibernate.connection.useUnicode">true</property>
        <property name="hibernate.connection.characterEncoding">UTF-8</property>


        <property name="show_sql">true</property>
        <property name="format_sql">true</property>
        <property name="hibernate.use_sql_comments">true</property>
        <property name="current_session_context_class">thread</property>

        <!-- configuration pool via c3p0-->
        <property name="c3p0.acquire_increment">1</property>
        <property name="c3p0.idle_test_period">100</property> <!-- seconds -->
        <property name="c3p0.max_size">100</property>
        <property name="c3p0.max_statements">0</property>
        <property name="c3p0.min_size">10</property>
        <property name="c3p0.timeout">100</property> <!-- seconds -->
        <!-- DEPRECATED very expensive property name="c3p0.validate>-->


    </session-factory>
</hibernate-configuration>

当我第一次运行我的程序时,它在数据库中创建了表,但我的问题是字符集仍然是latin1_swedish_ci (拉丁文),而不是utf8,我应该在hibernate.hbm.xml设置中做什么更改?

EN

回答 2

Stack Overflow用户

发布于 2011-01-10 16:58:35

我通过在my.cnf中设置character-set-server选项解决了这个问题

代码语言:javascript
复制
[mysqld]
character-set-server=utf8
票数 3
EN

Stack Overflow用户

发布于 2009-07-23 16:11:56

UTF-8设置与Hibernate配置其到数据库的运行时连接的方式有关。我猜它对模式创建没有影响,模式创建实际上是Hibernate的一个独立部分。

我发现,auto-DDL的东西只有在模式中生成初始阶段时才真正有用。我总是把那个DDL修改成我想要的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1172849

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档