java - 从@OneToMany 关系中删除一个 child

标签 java database hibernate one-to-many

在一对多关系中,如何删除子元素而不必查找并加载父元素、删除元素、更新父元素,然后删除子元素?为了进一步说明我的问题,我有两个类 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/

相关文章:

mysql - 简单但缓慢的查询

ios - FMDB SQLite 没有出现在我的设备中

mysql - phpmyadmin:数据库事件

java - 如何从 WSDL 文件生成 java 类

java - RFIDRW-E-232 无法理解来自 Raspberry Pi 的命令

java - "Delete Where"在 Hibernate 中级联删除?

mysql - Hibernate createSQLQuery 获取sql计数

java - Hibernate Criteria 加入最新状态和过滤结果

java - Selenium 集线器和节点问题

java - 什么是NullPointerException,我该如何解决?