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

2022-09-02 09:05:07

假设我们有 3 个实体对象类:

class Parent {
    String name;
    List<Child> children;
}

class Child {
    String name;
    Parent parent;
}

class Toy {
    String name;
    Child child;
}

如何使用 JPA2.x(或休眠)注释来:

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

我使用的是Hibernate 4.3.5和mysql 5.1.30。

谢谢


答案 1

实体状态转换应从父级级级传递到子项,而不是相反。remove

你需要这样的东西:

class Parent {

    String name;

    @OneToMany(mappedBy = "parent", fetch = FetchType.LAZY, cascade = CascadeType.ALL, orphanRemoval = true)
    List<Child> children = new ArrayList<>();

    public void addChild(Child child) {
        child.setParent(this);
        children.add(child);
    }

    public void removeChild(Child child) {
        children.remove(child);
        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;
}

答案 2

您应该使用 .这是Hibernate和JPA的常见注释。休眠有另一种类似的类型,如。CascadeType.REMOVECacadeTypeCascadeType.DELETE

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

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

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

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

推荐