[英]Hibernate many-to-many mapping to the same entity unidirectional
我有代表树节点类型的表。 下面的映射说明了节点的多对多映射。
@Entity
public class Node {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@ManyToMany
@JoinTable(name = "node_dependency",
joinColumns = {@JoinColumn(name = "parent_id")},
inverseJoinColumns = {@JoinColumn(name = "child_id")})
private List<Node> childNodes = new ArrayList<>();
}
它有效,但我想有单独的表映射以简化删除查询。
@Entity
public class NodeRelation {
@ManyToOne
private Node parent;
@ManyToOne
private Node child;
}
如果我有 NodeRelation,我可以很容易地找到在树的不同层上重复使用的节点,并且不能安全地删除,这更难做到而不是(节点上的一对多 + FK 上的多对一) NodeRelation) 仅多对多映射。
我尝试了用 NodeRelation 表示的复合键映射的不同组合,但没有运气(根据 db 模式的验证没有通过)。 请建议我在这个用例中哪个映射更好。
最好不要在Node
使用childNodes
关联。
将id
添加到NodeRelation
会很方便。
@Entity
public class Node {
@Id
@GeneratedValue
private Long id;
}
@Entity
public class NodeRelation {
@Id
@GeneratedValue
private Long id;
@ManyToOne
private Node parent;
@ManyToOne
private Node child;
}
您还可以向NodeRelation
添加唯一约束(parent, child)
(具有与@ManyToMany
连接表相同的行为)。
它只需要对NodeRelation
表进行查询。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.