1. 程式人生 > >Spring整合Hibernate後沒有自動在資料庫中建立表結構

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>