hibernate 级联删除时候的两种情况 之(一) 删除主表、关系表跟从一并都删除了

前阵子,使用Hibernate删除多对多删除的时候遇到了点问题,情况是这样的:
A表和B表存在多对多关系,设计表关联时,创建中间表C,定义两个外键字段A_ID和B_ID,分别关联A表主键和B表主键。

在A表对应的hbm文件中,<set name="Bs" table="C" cascade="delete">...</set>

上面的cascade设定了级联删,本意是想删除A记录时,顺便清除中间表的关联记录,然而并未如此,删除A记录时,不仅删了中间表的记录,连B表中关联的记录也一并被删除了,这样的操作有时是不允许的,如权限和角色,你删了权限,但不能也把角色一并删了吧!

试过N遍,实在没辙,就不设置cascade属性,而是在C表中对A_ID字段添加了级联删的约束,这样就可以实现在删除A表记录时,只删中间表相关的记录,但不会删B表记录。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值