度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 1396|回复: 8
打印 上一主题 下一主题

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

[复制链接]

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
跳转到指定楼层
楼主
发表于 2020-6-25 14:55:21 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
业务场景:
  某天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 选项会删除和此表主键相关联的所有约束!
一定慎用!!!


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
推荐
发表于 2020-6-28 14:33:28 | 只看该作者
回复 支持 0 反对 1

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
沙发
 楼主| 发表于 2020-6-25 14:55:55 | 只看该作者
cascade 选项会删除和此表主键相关联的所有约束!
一定慎用!!!
回复 支持 反对

使用道具 举报

141

主题

1551

帖子

3573

积分

论坛元老

Rank: 8Rank: 8

积分
3573
板凳
发表于 2020-6-25 17:21:06 | 只看该作者
回复 支持 反对

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
5#
 楼主| 发表于 2020-6-28 14:38:55 | 只看该作者
回复 支持 反对

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
6#
 楼主| 发表于 2020-6-28 14:39:50 | 只看该作者
回复 支持 反对

使用道具 举报

141

主题

1551

帖子

3573

积分

论坛元老

Rank: 8Rank: 8

积分
3573
7#
发表于 2020-6-28 18:05:33 | 只看该作者
回复 支持 反对

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
8#
发表于 2020-6-29 14:15:29 | 只看该作者
回复 支持 反对

使用道具 举报

141

主题

1551

帖子

3573

积分

论坛元老

Rank: 8Rank: 8

积分
3573
9#
发表于 2020-6-29 20:17:34 | 只看该作者
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-11-1 10:37 , Processed in 0.147406 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表