度量快速开发平台-专业、快速的软件定制快开平台
标题:
如何快速禁用约束 (解决ORA-O2266问题)
[打印本页]
作者:
fteair
时间:
2020-6-25 14:55
标题:
如何快速禁用约束 (解决ORA-O2266问题)
业务场景:
某天truncate大量表时遇到错误ORA-O2266:表中的唯一/主键被启用的外键引用,不想看ER图来禁用大量复杂约束,所以研发了三种套路...
一. 最偷懒套路
如果要一次性导出很多表, 懒得看ER图, 可以用巧办法:
PLSQL developer:
Tools
Export tables
选中要导出的所有表(按住Ctrl多选)
导出形式选 "SQL Inserts" 脚本
选择截断表 "Truncate tables "
选择禁用所有外键约束 "Disable foreign key constraints"
Where 条件选 "1=2"
最后点"Export"导出脚本
选完如下图
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
欢迎光临 度量快速开发平台-专业、快速的软件定制快开平台 (http://bbs.delit.cn/)
Powered by Discuz! X3.2