2009-07-23 7 views
5

To jest mój hibernate.hbm.xml i używam MySQLProblem z UTF-8 w Tworzenie schematu, Hibernate

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

gdy uruchomię mój program po raz pierwszy tworzy tabelę w bazie danych, ale mój problem jest Charset nadal jest latin1_swedish_ci (latin) i nie utf8 co powinienem zmienić w ustawieniach hibernate.hbm.xml?

+0

Które charset masz na myśli? MySQL zna przynajmniej cztery z nich: zestaw znaków serwera, zestaw znaków Db, zestaw znaków klienta i zestaw znaków Conn. –

+0

zestaw znaków serwera i zestaw znaków db – Am1rr3zA

Odpowiedz

0

Ustawienie UTF-8 dotyczy sposobu, w jaki Hibernate konfiguruje połączenia środowiska wykonawczego z bazą danych. Zgaduję, że nie ma to wpływu na tworzenie schematu, który jest naprawdę oddzielną częścią Hibernate.

Uważam, że rzeczy auto-DDL są naprawdę przydatne tylko do generowania początkowego noża w schemacie. Zawsze biorę ten DDL i modyfikuję go tak, aby był dokładnie tym, czego chcę.

+0

czy możesz wyjaśnić więcej o auto-DDL i jak mam z niego korzystać? – Am1rr3zA

+0

i dlaczego hibernacja nie jest w stanie zapewnić, że chcę stworzyć schemat InnoDB? coz defualt był MyISAM, ale kiedy używam org.hibernate.dialect.MySQL5InnoDBDialect , to zmień go na InnoDB !!! – Am1rr3zA

+0

Mam na myśli ustawienie hbm2ddl.auto, którego używasz w swojej konfiguracji. – skaffman

3

I rozwiązany ten problem przez ustawienie character-set-server opcję w my.cnf:

[mysqld] 
character-set-server=utf8