假设我们有3个实体对象类:
class Parent {
String name;
List<Child> children;
}
class Child {
String name;
Parent parent;
}
class Toy {
String name;
Child child;
}
如何将JPA2.x(或hibernate)注释用于:
我使用的是Hibernate 4.3.5和mysql 5.1.30。
由于
答案 0 :(得分:20)
正如this article中所述,remove
entity state transition应该从父级到子级级联,而不是相反。
你需要这样的东西:
class Parent {
String name;
@OneToMany(mappedBy = "parent", fetch = FetchType.LAZY, cascade = CascadeType.ALL, orphanRemoval = true)
List<Child> 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;
}
答案 1 :(得分:7)
您应该使用CascadeType.REMOVE
。这是Hibernate和JPA的通用注释。 Hibernate还有另一个类似CacadeType
的类似CascadeType.DELETE
。
父删除时自动删除所有子项(一对多)
class Parent {
String name;
@OneToMany(cascade = CascadeType.REMOVE)
List<Child> children;
}
删除子项时从子项列表中自动删除子项(多对一)
class Child {
String name;
@ManyToOne(cascade = CascadeType.REMOVE)
Parent parent;
}
当儿童移除(一对一)时自动删除玩具
class Toy {
String name;
@OneToOne(cascade = CascadeType.REMOVE)
Child child;
}
答案 2 :(得分:1)
orphanRemoval是删除所有孤儿实体示例:store(s)有书(b1,b2,b3),b1在这种情况下有title(t)如果删除了商店,某些书籍(b2,b3)将被删除。 B2和t仍然存在。如果您使用&#34; cascade= CascadeType.Remove
&#34;只是商店和所有书籍将被删除(只有&#34; t&#34;存在)。
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
,则不会执行自动操作,因为断开关系不是删除操作。