• 启动和禁用约束及删除违反约束的记录


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

    一、禁用约束

      alter table table_name disable novalidate constraint constraint_name

    二、批量导入数据

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

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

        sql>@oracle_home dbmsadminutlexpt1.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; 

  • 相关阅读:
    Spring Boot Logback 默认配置
    CAS 之 Https And Database Authentication(三)
    CAS 之 Hello World(二)
    CAS 之 Apereo CAS 简介(一)
    对 url 中含有的中文进行转码操作
    Python Hello World
    集合与数组简明介绍
    Javascript中使用WScript.Shell对象执行.bat文件和cmd命令
    WOL远程开机
    Windows Server 2016-Windows安全日志ID汇总
  • 原文地址:https://www.cnblogs.com/moonfans/p/3955499.html
Copyright © 2020-2023  润新知