JPA配置詳解之jpaProperties用法
JPA配置之jpaProperties
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:jpa="http://www.springframework.org/schema/data/jpa" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa-1.3.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd"> <!-- spring自動讀取指定位置的配置為簡到spring中 --> <context:property-placeholder location="classpath*:/application.properties"/> <context:component-scan base-package="com.shiroweb"> <!-- 掃描com.shiroweb包下除去@Controller以外註解的類 --> <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/> <context:exclude-filter type="annotation" expression="org.springframework.web.bind.annotation.ControllerAdvice"/> </context:component-scan> <!-- c3p0數據源配置 --> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"> <property name="driverClass" value="${jdbc.driver}"/> <property name="jdbcUrl" value="${jdbc.url}" /> <property name="user" value="${jdbc.username}"/> <property name="password" value="${jdbc.password}"/> </bean> <!-- Jpa Entity Manager 配置 關聯hibernateJpaVendorAdapter --> <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="jpaVendorAdapter" ref="hibernateJpaVendorAdapter"/> <property name="packagesToScan" value="com.shiroweb"/> <!-- <property name="jpaProperties"> <props> 命名規則 My_NAME->MyName <prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.ImprovedNamingStrategy</prop> 實體類對應數據庫沒有表 就生成一個表 <prop key="hibernate.hbm2ddl.auto">update</prop> </props> </property> --> <!-- 指定JPA屬性;如Hibernate中指定是否顯示SQL的是否顯示、方言等 --> <property name="jpaProperties"> <props> <!-- <prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop> --> <prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.ImprovedNamingStrategy</prop> <!-- <prop key="hibernate.cache.provider_class">org.hibernate.cache.NoCacheProvider</prop> --> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">true</prop> <!-- <prop key="hibernate.hbm2ddl.auto">validate</prop> --> <prop key="hibernate.hbm2ddl.auto">update</prop> </props> </property> </bean> <!-- 配置hibernateJpaVendorAdapter關聯數據源 --> <bean id="hibernateJpaVendorAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> <property name="database" value="MYSQL" /> <property name="showSql" value="true" /> </bean> <!-- Spring Data Jpa配置 --> <jpa:repositories base-package="com.shiroweb" transaction-manager-ref="transactionManager" entity-manager-factory-ref="entityManagerFactory"/> <!-- Jpa 事務配置 --> <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> <property name="entityManagerFactory" ref="entityManagerFactory"/> </bean> <!-- 使用annotation定義事務 --> <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true" /> </beans>
其中jpaProperties是這是jpa的一些屬性的
<!-- 指定JPA屬性;如Hibernate中指定是否顯示SQL的是否顯示、方言等 --> <property name="jpaProperties"> <props> <!-- <prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop> --> <prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.ImprovedNamingStrategy</prop> <!-- <prop key="hibernate.cache.provider_class">org.hibernate.cache.NoCacheProvider</prop> --> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.format_sql">true</prop> <!-- <prop key="hibernate.hbm2ddl.auto">validate</prop> --> <prop key="hibernate.hbm2ddl.auto">update</prop> </props> </property>
這裡有個屬性為
<prop key="hibernate.hbm2ddl.auto">update</prop>
這是一個有用的設置
其實這個hibernate.hbm2ddl.auto參數的作用主要用於:自動創建|更新|驗證數據庫表結構。如果不是此方面的需求建議set value=”none”。
create
:每次加載hibernate時都會刪除上一次的生成的表,然後根據你的model類再重新來生成新表,哪怕兩次沒有任何改變也要這樣執行,這就是導致數據庫表數據丟失的一個重要原因。create-drop
:每次加載hibernate時根據model類生成表,但是sessionFactory一關閉,表就自動刪除。update
:最常用的屬性,第一次加載hibernate時根據model類會自動建立起表的結構(前提是先建立好數據庫),以後加載hibernate時根據 model類自動更新表結構,即使表結構改變瞭但表中的行仍然存在不會刪除以前的行。要註意的是當部署到服務器後,表結構是不會被馬上建立起來的,是要等 應用第一次運行起來後才會。validate
:每次加載hibernate時,驗證創建數據庫表結構,隻會和數據庫中的表進行比較,不會創建新表,但是會插入新值。
Sping Data Jpa配置問題
spring.jpa.properties.hibernate.hbm2ddl.auto=update
在配置spring data jpa時,如果spring.jpa.properties.hibernate.hbm2ddl.auto設置為update,會自動更新數據表結構,比如Entity中增加成員變量,數據表中也會增加相應的字段,但是需要註意的是,如果刪除一個成員變量,這時數據表中不會自動刪除對應的字段,如果刪除的那個成員變量在數據表中被設置為not null,當再次運行時就會報錯,如下面的例子
新建一個實體類
import lombok.Data; import javax.persistence.*; @Entity @Data public class Car{ @Id @Column(name="id", nullable = false) @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(nullable = false) private String price; @Column private String color; @Column private String brand; }
這時可以在數據庫中看到已經自動生成數據表car,並且有對應的字段
這時我們刪掉Car中的price,重新運行,我們再次查看數據庫
發現還是存在price字段
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- Spring IOC容器基於XML外部屬性文件的Bean管理
- AOP之事務管理<aop:advisor>的兩種配置方式
- Spring概述和快速構建的方式
- Spring項目中使用Junit單元測試並配置數據源的操作
- Spring操作JdbcTemplate數據庫的方法學習