在一对多关系中,如何删除子元素而不必查找并加载父元素、删除元素、更新父元素,然后删除子元素?为了进一步说明我的问题,我有两个类 Foo( parent )和 Don(Don 的 child ):
@Entity
public class Foo {
@Id
@GeneratedValue
private int id;
@OneToMany
private List<Don> dons;
public int getId() {
return id;
}
public List<Don> getDons() {
// (loads dons as because lazy loading)
return dons;
}
}
@Entity
public class Don {
@Id
@GeneratedValue
private int id;
public int getId() {
return id;
}
}
如果我有一个 Don 实例,其中有多个 Foos 引用它,我会得到以下异常:
Cannot delete or update a parent row: a foreign key constraint fails
我知道我可以从 Foo 中删除实例,但是有没有办法在不找到 Foos 的情况下删除 Don 实例? (截至性能)
最佳答案
我认为你的情况应该是:删除一个 Foos
实例,多个 Dons
引用它
您可以添加cascade
属性,然后当您删除一个Foos
实例时,关联的Dons
实例将被自动删除而不会给出外键错误:
@OneToMany(cascade = {CascadeType.ALL})
private List<Don> dons;
关于java - 从@OneToMany 关系中删除一个 child ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28860888/