Spring Boot & Hibernate - x 实例的标识符被更改为 null



我们为所有名为 Heartcore 的实体提供了一个超类,带有 @MappedSuperclass .

@Id
private String id;
@Column(nullable = false)
@NonNull
private String uuid;
@NonNull
@Column(nullable = false)
private String kanton;
// specific Setter
public void setKanton(String kanton) {
  if (kanton != null) {
    id = uuid + "_" + kanton;
  }
  this.kanton = kanton;
}
public void setUuid(String uuid) {
  if (kanton != null) {
    id = uuid + "_" + kanton;
  }
  this.uuid = uuid;
}

我有以下单向一对一关系:

子实体

class OtoUniChild extends Heartcore {
@Id
private String id;
@OneToOne
@MapsId
private OtoUniParent otoUniParent;
public void setOtoUniParent(OtoUniParent otoUniParent) {
    if (otoUniParent != null) {
        if (StringUtils.isNoneBlank(otoUniParent.getUuid(), otoUniParent.getKanton())) {
            this.otoUniParent = otoUniParent;
            setUuid(otoUniParent.getUuid());
            setKanton(otoUniParent.getKanton());
            return;
        }
        throw new InvalidObjectException("Es wurde ein invalides Objekt übergeben!");
    }
    this.otoUniParent = null;
}

当我保留一个父级和一个子级,然后尝试从子存储库中获取一个子级时findById(149727fd-b0ce-4069-bcd9-d67fdbe69021_SG)我刚刚收到错误"org.springframework.orm.jpa.JpaSystemException: identifier of an instance of x.data.OtoUniChild was altered from 149727fd-b0ce-4069-bcd9-d67fdbe69021_SG to null;".我不知道这是怎么发生的!

*弹簧启动 v.1.5.8.发布

我相信

这是由于您的OtoUniChild类中的双重定义@Id:

  • 曾经Heartcore超阶级。
  • 一旦进入实体本身

虽然@MappedSuperclass不允许这样的重新定义,但你碰巧用相同的名称和类型重新定义它。但是,您仍然可以期望某些方法看到前者,而某些方法可以看到后者。

最新更新