spring boot使用jpa,可不可以动态生成数据库表

发布网友 发布时间:2022-04-24 04:29

我来回答

1个回答

热心网友 时间:2022-04-09 14:53

我最近使用springboot的时候也遇到跟你一样的问题
看我的BaseModel
public class BaseModel implements Serializable {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "id")
private Long id;

protected BaseModel(){
this.id = 1L;
}

public Long getId() {
return id;
}

public void setId(Long id) {
this.id = id;
}

public boolean equals(Object other) {
if (other == null || other.getClass() != this.getClass())
return false;
if(this.getId() == null || ((BaseModel) other).getId() == null) return false;
return this.getId().equals(((BaseModel) other).getId());
}

public int hashCode() {
return new HashCodeBuilder().append(getId()).toHashCode();
}

}

这里的BaseModel是我的实体类的父类,我错误的原因是序列化没有重写好equals函数,因为动态生成sql语句的时候主键默认为null,无法识别这是不是一个新的对象(我的理解),所以重写的时候多了
if(this.getId() == null || ((BaseModel) other).getId() == null) return false;

因为主键不为空,为null肯定不相等。我就这样解决了,不知道能不能帮到你了。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com