我将Spring Boot与Spring Data结合使用,并且为了保存实体,我使用CrudRepository。我有2个实体:Org和OrgDef。这个想法是为一个组织存储多个定义。 Org是不可变的部分,而OrgDef是可变的。它在代码中的外观如下:

@NoArgsConstructor(access = AccessLevel.PROTECTED)
@Getter
@Entity
@Table(name = "org", uniqueConstraints = {
    @UniqueConstraint(columnNames = { "code" }, name = "uk_org_code"),
    @UniqueConstraint(columnNames = { "definition_id"},
    name = "uk_org_definitionId")})
public class Org {

@Id
@Column(
    name = "id",
    updatable = false,
    nullable = false
)
protected UUID id = UUID.randomUUID();

@Column(updatable = false)
protected String code;

@JoinColumn(nullable = false, foreignKey = @ForeignKey(name = "fk_org_definition_orgDef"))
@OneToOne(optional = false, cascade = { CascadeType.PERSIST, CascadeType.MERGE })
protected OrgDef definition;

}



@NoArgsConstructor(access = AccessLevel.PROTECTED)
@Getter
@Setter
@Entity
@Table(name = "org_def")
public class OrgDef extends UuidIdEntity {

@Id
@Column(
    name = "id",
    updatable = false,
    nullable = false
)
protected UUID id = UUID.randomUUID();

@JoinColumn(foreignKey = @ForeignKey(name = "fk_orgDef_orgId_org"), updatable = false)
@ManyToOne
protected Org org;

@JoinColumn(foreignKey = @ForeignKey(name = "fk_orgDef_parentId_org"))
@ManyToOne
protected Org parent;
}


我还要指出,Org与OrgDef具有一对一的关系,而OrgDef与Org具有多对一的关系。另外,OrgDef具有“父”字段,该字段也具有“多对一”关系。当我保存此类的记录时,我将其保存在表中:

组织表:

java - 保存实体后 hibernate 一对一和多对一关系的奇怪行为-LMLPHP

OrgDef表:
java - 保存实体后 hibernate 一对一和多对一关系的奇怪行为-LMLPHP

您可以在表OrgDef字段中看到org_id为空,但parent_id不为空。但是在保存时,我在OrgDef对象中为org和parent字段都指定了Org对象。可能是映射问题?有人可以帮忙吗?因为OrgDef的父字段保存得很好,但是OrgDef中的org字段没有保存!我的期望是org_id和parent_id都不为空

最佳答案

我发现了问题,我在OrgDef类的org字段上使用了这个注释:

@JoinColumn(foreignKey = @ForeignKey(name = "fk_orgDef_orgId_org"), updatable = false)


我指定此字段不可更新,因此休眠状态无法向该字段插入值。我从此注释中删除了updatable = false,现在一切正常!

10-05 21:41