oracle 删除数据违反约束条件,Oracle启动和禁用约束及删除违反约束的记录

背景:在数据仓库中批量的导入数据的情况下,如果较多的约束存在那么会增加数据库的负担降低系统导入数据的效率,在这个情况下一般会采取牺牲约束的校验换取系统执行的效率。即禁用约束待数据全部导入成功以后再检查数据库中违反约束的数据,修改违规记录,最后重启约束。

一、禁用约束

alter table table_name disable novalidate constraint constraint_name

二、批量导入数据

三、在开启约束之前一定要检查违反约束的记录

1、执行Oracle中自带的脚本utlexpt1.sql创建exceptions表。该脚本在oracle_home/rdbms/admin目录下

sql>@oracle_home\rdbms\admin\utlexpt1.sql

2、执行带有exception是选项的alter语句,将违反约束条件的记录添加到exceptions表中保存

alter table table_name enable validate constraint constraint_name exceptions into sys.exceptions;

3、在exceptions表中使用子查询来锁定无效的数据行

select column1,column2,column3 from table_name where rowid in(

select row_id from sys.exceptions

) for update

4、根据查询结果修改违反约束的记录行(可以通过rowid来直接update)

5、重新执行带有alter 的开启约束的语句

alter table table_name enable validate constraint constraint_name

6、查询约束的状态是否为enable 、validate

select constraint_name,constraint_type,status,validated from dba_constraints where owner='OWNER' and table_name='TABLE_NAME';

四、确认exceptions表无用后删除或者truncate表

drop table sys.exceptions;

0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值