如何快速禁用约束 (解决ORA-O2266问题)

业务场景:
  某天truncate大量表时遇到错误ORA-O2266:表中的唯一/主键被启用的外键引用,不想看ER图来禁用大量复杂约束,所以研发了三种套路...
 
一. 最偷懒套路
如果要一次性导出很多表, 懒得看ER图, 可以用巧办法:
PLSQL developer:
  1. Tools
  2. Export tables
  3. 选中要导出的所有表(按住Ctrl多选)
  4. 导出形式选 "SQL Inserts" 脚本
  5. 选择截断表 "Truncate tables "
  6. 选择禁用所有外键约束 "Disable foreign key constraints"
  7. Where 条件选 "1=2"
  8. 最后点"Export"导出脚本
选完如下图
 
打开导出的脚本, 删除没用的东西, 剩下的就是清数脚本了

 
二. 最二笔套路 
哪个表报错就把哪个表单 truncate 改成 delete from;
大表时间会很长... 所以不建议使用!
 
 
三. 最危险套路
ORA-02266报错原因是因为DDL语句不会检查约束 , 所以根据错误提示 "表中的唯一/主键被启用的外键引用"
想到禁用表的唯一/主键 就可以进行truncate了
alter table rdxx disable constraints cascade;
truncate table rdxx;
alter table rdxx enable constraints;
 
 
cascade 选项会删除和此表主键相关联的所有约束!
 一定慎用!!!
 
 
posted @ 2017-08-24 10:56  学孩儿无牙哭做粥  阅读(498)  评论(0编辑  收藏  举报