概述
最近刚接触JPA就遇到一个一对多级联更新的棘手问题
父类A(为简单只写主要部分)
class A{
@OneToMany(cascade = CascadeType.ALL, mappedBy = "a")
private List<B> bs=new ArrayList<B>();
}
子类B
class B{
@ManyToOne
private A a;
}
假如当A对象的bs中有两个B对象,当删除其中一个B对象后,再对A对象进行保存,子类B对应的数据表中应该删除这条记录,可事实并非如此;当A对象的bs中有新增或某个B对象更新属性后,保存A对象会级联更新B表,唯独删除不行。
后查资料须在@OneToMany中增加属性orphanRemoval = true,同时在操作A对象时一定要注意bs的引用不能改变,具体例子如下:
假如改变后的列表放在 private List<B> bs_new中
A a=dao.findbyId(id);
a.getBS.clear();
a.getBS.addAll(bs_new);
如果用类似a.setBS(bs_new);这种方式会报错,因为bs属性的引用已经发生了变化。
最后
以上就是奋斗白羊为你收集整理的JPA @onetomany 解决孤子问题的全部内容,希望文章能够帮你解决JPA @onetomany 解决孤子问题所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复