91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JPA中jpaProperties怎么用

發布時間:2021-11-22 11:52:39 來源:億速云 閱讀:164 作者:小新 欄目:開發技術

這篇文章主要為大家展示了“JPA中jpaProperties怎么用”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“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,并且有對應的字段

JPA中jpaProperties怎么用

這時我們刪掉Car中的price,重新運行,我們再次查看數據庫

JPA中jpaProperties怎么用

發現還是存在price字段

以上是“JPA中jpaProperties怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

jpa
AI

沙坪坝区| 山阴县| 垣曲县| 库尔勒市| 织金县| 杭锦旗| 美姑县| 白沙| 新民市| 卓资县| 五原县| 柞水县| 江口县| 荔波县| 全南县| 二连浩特市| 黎平县| 广德县| 区。| 阿鲁科尔沁旗| 得荣县| 桂平市| 龙陵县| 富民县| 巴中市| 开阳县| 德阳市| 合阳县| 蕲春县| 泰安市| 扬中市| 阜南县| 抚顺市| 从江县| 明光市| 扎兰屯市| 四平市| 洛浦县| 登封市| 漾濞| 昌邑市|