繁体   English   中英

从@OneToMany关系中删除一个孩子

[英]Delete a child from a @OneToMany relationship

在一对多关系中,如何删除子元素而不必查找并加载父元素,删除元素,更新父元素,然后删除子元素? 为了进一步说明我的问题,我有Foo(父级)和Don(Don的子级)两个类:

@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引用该实例,则将出现以下异常:

无法删除或更新父行:外键约束失败

我知道我可以从Foo中删除实例,但是有没有一种方法可以在不找到Foos的情况下删除Don实例? (截至性能)

我认为您的情况应该是: 删除有几个Dons引用的Foos实例

您可以添加cascade属性,然后在删除Foos实例时,关联的Dons实例将被自动删除而不会出现外键错误:

@OneToMany(cascade = {CascadeType.ALL})
private List<Don> dons;

这篇文章所述,需要双向绑定才能删除对象。 从Don到Foo的引用添加了@ManyToOne批注,并向Foo.dons添加了mappingBy =“ parent”解决了我的问题。 最终代码:

@Entity
 public class Foo {
    @Id
    @GeneratedValue
    private int id;

    // Added mapped by, which refers to Don.parent
    @OneToMany(mappedBy = "parent")
    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;

    // Added parent
    @ManyToOne
    private Foo parent;

    public int getId() {
        return id;
    }

    // Remember to set parent, otherwise we will loose the reference in the database.
    public void setParent(Foo parent) {
        this.parent = parent;
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM