玉祥平台客服-15087858732

标题: 如何快速禁用约束 (解决ORA-O2266问题) [打印本页]

作者: fteair    时间: 2020-6-25 14:55
标题: 如何快速禁用约束 (解决ORA-O2266问题)
业务场景:
  某天truncate大量表时遇到错误ORA-O2266:表中的唯一/主键被启用的外键引用,不想看ER图来禁用大量复杂约束,所以研发了三种套路...

一. 最偷懒套路
如果要一次性导出很多表, 懒得看ER图, 可以用巧办法:
PLSQL developer:
选完如下图

file:///C:/Users/Administrator/Documents/My%20Knowledge/temp/45091c73-9aa6-45d7-a694-94a1ec454347/128/index_files/96900446-1f91-4d00-8f66-e6afa38ca07b.png

打开导出的脚本, 删除没用的东西, 剩下的就是清数脚本了



二. 最二笔套路
哪个表报错就把哪个表单 truncate 改成 delete from;
大表时间会很长... 所以不建议使用!


三. 最危险套路
ORA-02266报错原因是因为DDL语句不会检查约束 , 所以根据错误提示 "表中的唯一/主键被启用的外键引用"
想到禁用表的唯一/主键 就可以进行truncate了
alter table rdxx disable constraints cascade;
truncate table rdxx;
alter table rdxx enable constraints;


cascade 选项会删除和此表主键相关联的所有约束!
一定慎用!!!



作者: fteair    时间: 2020-6-25 14:55
cascade 选项会删除和此表主键相关联的所有约束!
一定慎用!!!

作者: caixuqad    时间: 2020-6-25 17:21

作者: 张兴康    时间: 2020-6-28 14:33

作者: fteair    时间: 2020-6-28 14:38
caixuqad 发表于 2017-8-25 17:21


作者: fteair    时间: 2020-6-28 14:39
张兴康 发表于 2017-8-28 14:33


作者: caixuqad    时间: 2020-6-28 18:05

作者: 张兴康    时间: 2020-6-29 14:15
caixuqad 发表于 2017-8-28 18:05


作者: caixuqad    时间: 2020-6-29 20:17





欢迎光临 玉祥平台客服-15087858732 (http://bbs.delit.cn/) Powered by Discuz! X3.2