oracle中的级联删除

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


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

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

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

3、从父表删除记录;

4、逐层恢复原有外键。
   

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