【发布时间】:2021-06-01 12:56:11
【问题描述】:
这是我正在处理的代码结构。
@Data
public class ParentKey implements Serializable {
/**
*
*/
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(generator= "uuid")
@GenericGenerator(name="uuid", strategy="uuid2")
private String Pa;
@Id
private String Pb;
// ignoring getters and setters and hashcode and equals()
}
@Entity
@IdClass(ParentKey.class)
@Table(name="parent_demo")
public class Parent_Demo {
@Id
private String Pa;
@Id
// @Column(name="p_b")
private String Pb;
@OneToMany(cascade=CascadeType.ALL,orphanRemoval=true )
@JoinColumn(name="p_a_fk", referencedColumnName="Pa")
@JoinColumn(name="p_b_fk", referencedColumnName="Pb")
private List<Child_Demo> childs = new ArrayList<>();
private String pc;
// ignoring getter and setters
}
@Data
public class ChildKey implements Serializable {
/**
*
*/
private static final long serialVersionUID = 1L;
@Id
private String ca;
@Id
private String cb;
@Id
private String Pa;
}
@Entity
@IdClass(ChildKey.class)
@Table(name="child_demo")
public class Child_Demo {
@Id
private String Pa; // can i link this value to the value of Pa in ParentKey which is being autogenerated
@Id
private String ca;
@Id
private String cb;
private String cc;
private String cd;
我想创建一对多的单向映射,其中父键的一部分是自动生成的,另一部分是在 api 调用期间在请求正文中发送的。类似地,在 api 调用期间,ca 和 cb 将在 Request Body 中发送。我想确保 Pa 也成为孩子复合主键的一部分。 下面的代码生成 2 个表 parent_demo 以 (pa,pb) 作为主键和 child_demo 以 (pa,ca,cb) 作为主键。但是,在进行 post api 调用时,我得到了违反 not null 约束,因为 child_demo 中的 pa 为 null。我想将 parent_demo 中的 pa(自动生成)的值复制到 child_demo 中的 pa。
有人可以帮忙吗?
【问题讨论】:
-
我认为这在这个例子中是行不通的,因为你的子实体的 PK 只引用了父实体的复合 PK 的一部分。子表的 PK 必须引用父 PK 的所有部分。否则它是多对多关系,必须这样注释。
标签: java database spring-boot jpa