Spring整合Hibernate後沒有自動在資料庫中建立表結構
Hibernate配置檔案hibernate.cfg.xml中關於SessionFactory節點配置通常如下:
<session-factory> <!-- Database connection settings --> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <property name="connection.url">jdbc:mysql://localhost:3306/databaseName</property> <property name="connection.username">usernameDemo</property> <property name="connection.password">passwordDemo</property> <!-- SQL dialect --> <property name="dialect">org.hibernate.dialect.MySQLDialect</property> <!-- JDBC connection pool (use the built-in) --> <property name="connection.pool_size">1</property> <!-- Enable Hibernate's automatic session context management --> <property name="current_session_context_class">thread</property> <!-- Disable the second-level cache --> <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property> <!-- Echo all executed SQL to stdout --> <property name="show_sql">true</property> <!-- Drop and re-create the database schema on startup --> <property name="hbm2ddl.auto">update</property> <!-- Format SQL --> <property name="format_sql">true</property> <mapping resource="com/lemmata/pojo/tableDemo.hbm.xml" /> </session-factory>
其中<property name="hbm2ddl.auto">update</property>節點的作用是:"Drop and re-create the database schema on startup".
Spring整合Hibernate後,可以將Hibernate的SessionFactory完全交給Spring來管理,並且可以使用Spring AOP來實現宣告式事務管理。簡化Hibernate開發的同時,也可以完全使用Spring配置檔案來替代Hibernate的配置檔案。
Spring配置檔案applicationContext.xml中關於SessionFactory節點的配置通常如下:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource"></property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> <prop key="current_session_context_class">thread</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hbm2ddl.auto">update</prop> </props> </property> <!-- 按照檔案方式指定 --> <!-- <property name="mappingResources"> <list> <value>com/lemmata/pojo/tableDemo.hbm.xml</value> </list> </property> --> <!-- 按照目錄方式指定 --> <property name="mappingDirectoryLocations"> <list> <value>classpath:/com/lemmata/pojo</value> </list> </property> </bean>
其中容易產生問題的地方在於:
<property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> <prop key="current_session_context_class">thread</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hbm2ddl.auto">update</prop> </props> </property>
有些prop節點的key帶有“hibernate”做字首,有些沒有帶“ibernate”,而且不同資料庫的不同版本對於“<prop key="hbm2ddl.auto">update</prop>”節點是否需要“hibernate”做字首也有不同的要求,因此如果發現Hibernate某項屬性值失效,可在對應屬性前補充上“hibernate”字元作為字首即可。
例如,如果發現Spring整合Hibernate之後沒有在載入配置時自動建立資料庫架構,解決方法是:可以在<prop key="hbm2ddl.auto">update</prop>節點的key中補充上“hibernate”字元作為字首即可,如:
<prop key="hibernate.hbm2ddl.auto">update</prop>