配置自動建立表:java
<prop key="hibernate.hbm2ddl.auto">update</prop>//首次建立項目時用,項目穩定後通常註釋
這裏有是個值:spring
update:表示自動根據model對象來更新表結構,啓動hibernate時會自動檢查數據庫,若是缺乏表,則自動建表;若是表裏缺乏列,則自動添加列。sql
還有其餘的參數:
create:啓動hibernate時,自動刪除原來的表,新建全部的表,因此每次啓動後的之前數據都會丟失。 數據庫
create-drop:啓動hibernate時,自動建立表,程序關閉時,自動把相應的表都刪除。因此程序結束時,表和數據也不會再存在。
validate :
每次加載hibernate時,驗證建立數據庫表結構,只會和數據庫中的表進行比較,不會建立新表,可是會插入新值。
session
而後在配置 讀取實體類映射:app
有3種方法:url
一、(經常使用)spa
經過註解掃描包的方式:
<property name="packagesToScan">
<list><value>com.systop.common.core.dao.testmodel</value></list>hibernate
二、
code
經過註解的方式:
<property name="annotatedClasses">
<list><value>com.systop.common.core.dao.testmodel.TestDept</value></list>
</property>
三、
mappingResources用於指定少許的hibernate配置文件像這樣
Xml代碼
<property name="mappingResources">
<list>
<value>WEB-INF/conf/hibernate/cat.hbm.</value>
<value>WEB-INF/conf/hibernate/dog.hbm.xml</value>
......
</list>
</property>
實例:
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath*:/dataSource/jdbc.properties</value> </list> </property> </bean> <!-- 配置數據源 --> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" > <property name="driverClassName" value="${jdbcCcbs.driverClassName}"/> <property name="url" value="${jdbcCcbs.url}"/> <property name="username" value="${jdbcCcbs.username}"/> <property name="password" value="${jdbcCcbs.password}"/> </bean> <!-- 配置SessionFactory--> <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> <!--<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">--> <property name="dataSource" ref="dataSource" /> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> <!--自動建立表配置--> <!--<prop key="hibernate.hbm2ddl.auto">update</prop>--> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">true</prop> <!--結果滾動集,跟分頁有關--> <prop key="jdbc.use_scrollable_resultset">false</prop> </props> </property> <!--<property name="annotatedClasses">--> <!--<list>--> <!--<value>com.jason.entity.UserEntity</value>--> <!--</list>--> <!--</property>--> <property name="packagesToScan"> <list> <value>com.jason.entity</value> </list> </property> </bean>