Mysql 通过Hibernate创建架构时UTF-8出现问题

Mysql 通过Hibernate创建架构时UTF-8出现问题,mysql,hibernate,unicode,character-encoding,Mysql,Hibernate,Unicode,Character Encoding,这是我的hibernate.hbm.xml 我使用MySQL <?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"> <hibe

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

<?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>

org.hibernate.dialogue.mysql5innodbdialogue
com.mysql.jdbc.Driver
jdbc:mysql://localhost:3306/dbName?autoReconnect=true&useUnicode=true&;characterEncoding=UTF-8
根
******
更新
真的
UTF-8
真的
真的
真的
线
1.
100
100
0
10
100

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

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


我发现auto-DDL只在生成模式的初始尝试时才真正有用。我总是使用该DDL,并将其修改为我想要的内容。

我通过在
my.cnf
中设置
字符集服务器
选项解决了这个问题:

[mysqld]
character-set-server=utf8

你能解释更多关于自动DDL的内容吗?我应该如何使用它?为什么hibernate不支持我创建InnoDB模式?因为defualt是MyISAM,但当我使用org.hibernate.dialogue.mysql5innodbdialogue时,它将其更改为InnoDB!!!我指的是您在配置中使用的hbm2ddl.auto设置。您指的是哪个字符集?MySQL至少知道其中的四个:服务器字符集、Db字符集、客户端字符集以及Conn.characterset.Server字符集和Db字符集