Am1*_*3zA 5 mysql unicode hibernate 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">
<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&useUnicode=true&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>
Run Code Online (Sandbox Code Playgroud)
当我第一次运行我的程序时它在数据库中创建了表但我的问题是Charset仍然是latin1_swedish_ci(拉丁语)并且不是utf8我应该在hibernate.hbm.xml设置中更改什么?
UTF-8 设置与 Hibernate 配置其与数据库的运行时连接的方式有关。我猜它对模式创建内容没有影响,这实际上是 Hibernate 的一个独立部分。
我发现自动 DDL 的东西只对生成模式的初始测试才真正有用。我总是采用该 DDL 并将其修改为我想要的。
| 归档时间: |
|
| 查看次数: |
5732 次 |
| 最近记录: |