我将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具有“父”字段,该字段也具有“多对一”关系。当我保存此类的记录时,我将其保存在表中:
组织表:
OrgDef表:
您可以在表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
,现在一切正常!