springboot JPA动态生成 sql 语句出现的问题

springboot 采用 @DynamicInsert 动态生成 sql 语句时,我采用的 springboot JPA的 save()放大时,如果没有设置主键会抛出空指针异常。我数据库的主键自增策略是 auto.

2个回答

我最近使用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肯定不相等。我就这样解决了,不知道能不能帮到你了。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问