JPA配置详解之jpaProperties用法

网友投稿 300 2022-11-21

JPA配置详解之jpaProperties用法

目录JPA配置之jpaPropertiesSping Data Jpa配置问题spring.jpa.properties.hibernate.hbm2ddl.auto=update

JPA配置之jpaProperties

xmlns:xsi="http://w3.org/2001/XMLSchema-instance"

xmlns:context="http://springframework.org/schema/context"

xmlns:aop="http://springframework.org/schema/aop"

xmlns:jpa="http://springframework.org/schema/data/jpa"

xmlns:tx="http://springframework.org/schema/tx"

xsi:schemaLocation="http://springframework.org/schema/aop http://springframework.org/schema/aop/spring-aop-4.1.xsd

http://springframework.org/schema/beans http://springframework.org/schema/beans/spring-beans.xsd

http://springframework.org/schema/data/jpa http://springframework.org/schema/data/jpa/spring-jpa-1.3.xsd

http://springframework.org/schema/tx http://springframework.org/schema/tx/spring-tx-3.2.xsd

http://springframework.org/schema/context http://springframework.org/schema/context/spring-context-4.1.xsd">

org.hibernate.cfg.ImprovedNamingStrategy

true

true

update

xmlns:xsi="http://w3.org/2001/XMLSchema-instance"

xmlns:context="http://springframework.org/schema/context"

xmlns:aop="http://springframework.org/schema/aop"

xmlns:jpa="http://springframework.org/schema/data/jpa"

xmlns:tx="http://springframework.org/schema/tx"

xsi:schemaLocation="http://springframework.org/schema/aop http://springframework.org/schema/aop/spring-aop-4.1.xsd

http://springframework.org/schema/beans http://springframework.org/schema/beans/spring-beans.xsd

http://springframework.org/schema/data/jpa http://springframework.org/schema/data/jpa/spring-jpa-1.3.xsd

http://springframework.org/schema/tx http://springframework.org/schema/tx/spring-tx-3.2.xsd

http://springframework.org/schema/context http://springframework.org/schema/context/spring-context-4.1.xsd">

org.hibernate.cfg.ImprovedNamingStrategy

true

true

update

其中jpaProperties是这是jpa的一些属性的

org.hibernate.cfg.ImprovedNamingStrategy

true

true

update

这里有个属性为

update

这是一个有用的设置

其实这个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字段

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:服务器上的硬盘接口技术解析
下一篇:K8S部署Kafka集群 - 部署笔记
相关文章

 发表评论

暂时没有评论,来抢沙发吧~