JPA配置详解之jpaProperties⽤法
⽬录
JPA配置之jpaProperties
SpingDataJpa配置问题
spring.jpa.properties.hibernate.hbm2ddl.auto=update
JPA配置之jpaProperties
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="/schema/beans"
xmlns:xsi="/2001/XMLSchema-instance"
xmlns:context="/schema/context"
xmlns:aop="/schema/aop"
xmlns:jpa="/schema/data/jpa"
xmlns:tx="/schema/tx"
xsi:schemaLocation="/schema/aop /schema/aop/spring-aop-4.1.xsd /schema/beans /schema/beans/spring-beans.xsd
/schema/data/jpa /schema/data/jpa/spring-jpa-1.3.xsd
/schema/tx /schema/tx/spring-tx-3.2.xsd
/schema/context /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="hange.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="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="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="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,当再次运⾏时就会报错,如下⾯的例⼦spring怎么读取properties
新建⼀个实体类
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字段
以上为个⼈经验,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论