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

use*_*877 13 java orm hibernate jpa hibernate-mapping

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

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

class Child {
    String name;
    Parent parent;
}

class Toy {
    String name;
    Child child;
}
Run Code Online (Sandbox Code Playgroud)

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

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

我正在使用Hibernate 4.3.5和mysql 5.1.30.

谢谢

Vla*_*cea 26

正如本文所解释的那样,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;
}
Run Code Online (Sandbox Code Playgroud)


Mas*_*dul 7

你应该用CascadeType.REMOVE.这是Hibernate和JPA的通用注释.Hibernate有另一种类CacadeType似的类型CascadeType.DELETE.

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

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

    class Child {
     String name;
     @ManyToOne(cascade = CascadeType.REMOVE)
     Parent parent;
    }
    
    Run Code Online (Sandbox Code Playgroud)
  3. 儿童移除时自动删除玩具(一对一)

    class Toy {
      String name;
      @OneToOne(cascade = CascadeType.REMOVE)
      Child child;
    }
    
    Run Code Online (Sandbox Code Playgroud)

  • 您为什么要将删除从Child级联到父级,或从玩具级联到子级.这意味着当我移除一个玩具时,我会移除孩子,并将其父母全部移走. (8认同)