`

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
分享到:
评论
1 楼 ljm1227134894 2012-07-06  
而是在C表中对A_ID字段添加了级联删的约束,  请问是如何约束的?

相关推荐

Global site tag (gtag.js) - Google Analytics