Hibernate级联删除的问题
在one-to-many 关联时,one方一般都需要有控制级联操作的权限,比如级联保存,级联删除等。
@OneToMany(mappedBy="table1", fetch = FetchType.LAZY, targetEntity = table2.class, cascade=CascadeType.ALL)
@ManyToOne(optional = true, fetch = FetchType.LAZY, targetEntity=table1.class ) @JoinColumn(name = "table1_ID")
问题-:
在下代码中:
Set<table2> set = table1.getTable2;
for (table2 t : set) {
if (t.getId == 1) {
table2Service.remove(t);
}
}
会产生:deleted object would be re-saved by cascade (remove deleted object from associations)
这是因为级联操作时由主控方来执行删除操作,子方执行删除操作就会抛出上面的异常。
解决的方法很简单:在执行remove方法前去除他们对象之的关联: table1.setTable2(null);
下面再执行删除就不会报错了。
相关推荐
fwens 2013-08-05
翡翠谷 2020-04-29
凤影 2011-08-15
sophia0 2012-03-21
yanit 2012-10-22
lhd0 2011-03-07
especialjie 2010-05-12
liuyiy 2013-06-14
LaputaSpring 2006-12-26
xing00 2006-12-09
Excalibur0 2013-06-27
天使 2011-07-13
执米之手与米偕老 2012-02-15
anshenoracle 2011-10-15
comedate 2019-04-12
勿念勿扰相安静好 2010-06-09
一个好人 2009-06-17
jackyfever 2019-04-06