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);

下面再执行删除就不会报错了。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值