Hibernate多对多级联删除
推荐:红番薯给力吧!
又一村遗失的记忆
前阵子,使用Hibernate删除多对多删除的时候遇到了点问题,情况是这样的:
A表和B表存在多对多关系,设计表关联时,创建中间表C,定义两个外键字段A_ID和B_ID,分别关联A表主键和B表主键。
在A表对应的hbm文件中,<setname="Bs"table="C"cascade="delete">...</set>
上面的cascade设定了级联删,本意是想删除A记录时,顺便清除中间表的关联记录,然而并未如此,删除A记录时,不仅删了中间表的记录,连B表中关联的记录也一并被删除了,这样的操作有时是不允许的,如权限和角色,你删了权限,但不能也把角色一并删了吧!
试过N遍,实在没辙,就不设置cascade属性,而是在C表中对A_ID字段添加了级联删的约束,这样就可以实现在删除A表记录时,只删中间表相关的记录,但不会删B表记录。