oracle中的级联删除(转)

oracle中的级联删除(转)[@more@]在oracle中,创建表之间的外键关联时,有个“on delete cascade”选项,应用这个选项可以在父表记录删除时,自动删除子表中的相应记录。但是这个选项十分危险,我在google上搜了一圈,发现实际使用这个选项的并不多,都是担心误删重要数据。


但是有时又的确需要这样的级联删除功能,避免繁琐的delete操作。我想到了一个利用数据字典表进行自动级联删除的办法,不过由于较复杂,暂时还没实现。思路如下:

1、采用递归的方式从父表出发,逐级查找子表;

2、从最底层的子表开始,依次更改其外键为“on delete cascade”方式;

3、从父表删除记录;

4、逐层恢复原有外键。


其实如果表的数量不太多,关联层次不复杂,完全可以手工删除或者使用存储过程/脚本用静态SQL的方式进行删除,而不必按照上述方法进行“自动”删除。
这里又牵扯到一个数据库的设计问题,我个人认为,表之间的关联关系不宜太复杂,在数据库层面应该尽可能划分模块,关联关系应该仅存在于模块内部。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10617542/viewspace-961520/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10617542/viewspace-961520/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值