双向一对多的删除

在使用JPA(hibernate)配置实体关系中,经常会遇到通过父实体对象级联批量更新子对象的需求,而且每次更新必须采用合并方式,即原来的所有子删除,只保留本次保存的所有子实体对象。

对于JPA中的双向一对多的模型中,现实系统总会有要求删除“多”一侧的数据,举例而言,订单Order和订单项OrderItem是一对多的关系

public class Order{
@OneToMany(mappedBy = "order", cascade = CascadeType.ALL, fetch = FetchType.EAGER,orphanRemoval = true)
    private Set<OrderItem> items = new HashSet<>();
}

public class OrderItem {
@ManyToOne
    @JoinColumn(name = "order_id")
    private Order order;
}

当修改订单的时候,有时候希望保持原有所有记录的ID,删除一部分OrderItem。那么我们就需要在Order一侧对@OneToMany添加属性 orphanRemoval = true,即删除孤儿对象。

第一次保存:假设Order下有三个OrderItem, 保存Order后,OrderItem对象对应的数据表ID为:1,2,3
第二次保存:假设该Order删除了id=1的OrderItem,同时添加了新的OrderItem,保存时候该新的对象的ID=4.那么保存该Order后,OrderItem对象的ID应该是2,3,4.(id=1的对象自动删除,不需要任何干预)
这个就是自动去孤子功能。


需要注意的是,当修改对象时候,需要把其关联的id和version提取到前台,保存的时候需要设置回去。



你可能感兴趣的:(双向一对多的删除)