在配置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字段

本文讨论了在使用Spring Data JPA时,将`spring.jpa.properties.hibernate.hbm2ddl.auto`设置为`update`如何影响数据库表结构的自动更新。当实体类新增字段时,数据库表会相应添加字段,但若删除字段,数据库表不会自动移除,可能导致运行时错误。举例说明了删除非空字段后的潜在问题。
最低0.47元/天 解锁文章
1093

被折叠的 条评论
为什么被折叠?



