使用JPA注释自动从子项中删除子项和父项

假设我们有3个Entities对象类:

class Parent { String name; List children; } class Child { String name; Parent parent; } class Toy { String name; Child child; } 

如何使用JPA2.x(或hibernate)注释:

  1. 父删除时自动删除所有子项(一对多)
  2. 删除子项时从子项列表中自动删除子项(多对一)
  3. 移除子女时自动删除玩具(一对一)

我正在使用Hibernate 4.3.5和mysql 5.1.30。

谢谢

正如本文中所解释的, remove 实体状态转换应该从父级转换为子级,而不是相反。

你需要这样的东西:

 class Parent { String name; @OneToMany(mappedBy = "parent", fetch = FetchType.LAZY, cascade = CascadeType.ALL, orphanRemoval = true) List children; public void addChild(Child child) { child.setParent(this); children.add(child); } public void removeChild(Child child) { children.remove(child); if (child != null) { child.setParent(null); } } } class Child { String name; @ManyToOne Parent parent; @OneToOne(mappedBy = "child", cascade = CascadeType.ALL, orphanRemoval = true) Toy toy; } class Toy { String name; @OneToOne Child child; } 

您应该使用CascadeType.REMOVE 。 这是Hibernate和JPA的通用注释。 Hibernate有另一个类似CacadeType类型,如CascadeType.DELETE

  1. 父删除时自动删除所有子项(一对多)

     class Parent { String name; @OneToMany(cascade = CascadeType.REMOVE) List children; } 
  2. 删除子项时从子项列表中自动删除子项(多对一)

     class Child { String name; @ManyToOne(cascade = CascadeType.REMOVE) Parent parent; } 
  3. 移除子女时自动删除玩具(一对一)

     class Toy { String name; @OneToOne(cascade = CascadeType.REMOVE) Child child; } 

orphanRemoval删除所有孤儿实体示例:store(s)有书籍(b1,b2,b3),b1在这种情况下有title(t),如果删除了商店,某些书籍(b2,b3)将被删除。 B2和t仍然存在。 如果你使用“ cascade= CascadeType.Remove ”只是存储,所有书籍将被删除(只有“t”存在)。

 s->b1,b2,b3 b2->t ------after(orphanRemoval = true)--------- b2->t s->b1,b2,b3 b2->t ------ after(cascade=CascadeType.REMOVE)--------- t 

如果指定了orphanRemoval = true,则会自动删除已断开连接的实体实例。 这对于清除没有所有者对象引用时不应存在的依赖对象很有用。

如果仅指定了cascade=CascadeType.REMOVE则不会执行自动操作,因为断开关系不是删除操作。