• oracle exp方式导出的dmp备份文件,imp 方式导入主外键约束问题处理


    【备份语句】

    导出语句:exp ACTIVITI/ACTIVITI@OA owner=OA file=ACTIVITI2020.DMP log=log.txt

    导入语句:imp ACTIVITI/ACTIVITI@OA file=ACTIVITI2020.dmp log=log.txt full=y ignore=y

    废话不多说,直接上错误日志;

    连接到: Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
    With the Partitioning, OLAP, Data Mining and Real Application Testing options
    
    经由常规路径由 EXPORT:V11.02.00 创建的导出文件
    已经完成 ZHS16GBK 字符集和 AL16UTF16 NCHAR 字符集中的导入
    . 正在将 ACTIVITI 的对象导入到 ACTIVITI
    . . 正在导入表                   "ACT_EVT_LOG"导入了           0 行
    . . 正在导入表              "ACT_GE_BYTEARRAY"
    IMP-00019: 由于 ORACLE 错误 2291 而拒绝行
    IMP-00003: 遇到 ORACLE 错误 2291
    ORA-02291: 违反完整约束条件 (ACTIVITI.ACT_FK_BYTEARR_DEPL) - 未找到父项关键字
    列 1 1062 13 bpmn/GroupCivilizationCommittee.png
    列 4 1055 00780001010C080000010000000100001246D573000376DA00...
    列 6 0
    IMP-00019: 由于 ORACLE 错误 2291 而拒绝行
    IMP-00003: 遇到 ORACLE 错误 2291
    ORA-02291: 违反完整约束条件 (ACTIVITI.ACT_FK_BYTEARR_DEPL) - 未找到父项关键字
    列 1 1072 13 bpmn/GroupCivilizationCommittee.bpmn20.xml
    列 4 1055 006C0001010C080000010000000100001246D574000376DA00...
    列 6 0
    IMP-00019: 由于 ORACLE 错误 2291 而拒绝行
    IMP-00003: 遇到 ORACLE 错误 2291
    ORA-02291: 违反完整约束条件 (ACTIVITI.ACT_FK_BYTEARR_DEPL) - 未找到父项关键字
    列 1 1102 13 bpmn/GroupOrgPartyCommittee.bpmn20.xml
    列 4 1095 006C0001010C080000010000000100001246D575000376DA00...
    列 6 0
    IMP-00019: 由于 ORACLE 错误 2291 而拒绝行
    IMP-00003: 遇到 ORACLE 错误 2291
    ORA-02291: 违反完整约束条件 (ACTIVITI.ACT_FK_BYTEARR_DEPL) - 未找到父项关键字
    列 1 1112 13 bpmn/GroupOrgPartyCommittee.png
    列 4 1095 00780001010C080000010000000100001246D576000376DA00...
    列 6 0

    导入完成后,发现表里数据不完整,纳尼头大了;看日志,发现是由于导入的时候,表直接存在主外键约束问题,引起的错误;

    解决思路:先禁用约束,导完后再启用。

    1.编写过程,禁用约束

    CREATE OR REPLACE PROCEDURE MANAGE_USER_CONSTRAINTS(OPERATION VARCHAR2,
                                                      FK        BOOLEAN DEFAULT TRUE,
                                                      PK        BOOLEAN DEFAULT TRUE,
                                                      UK        BOOLEAN DEFAULT TRUE) IS
    ST VARCHAR2(255);
    CURSOR R IS
      SELECT TABLE_NAME, CONSTRAINT_NAME
        FROM USER_CONSTRAINTS
       WHERE CONSTRAINT_TYPE = 'R';
    
    CURSOR P IS
      SELECT TABLE_NAME, CONSTRAINT_NAME
        FROM USER_CONSTRAINTS
       WHERE CONSTRAINT_TYPE = 'P';
    
    CURSOR U IS
      SELECT TABLE_NAME, CONSTRAINT_NAME
        FROM USER_CONSTRAINTS
       WHERE CONSTRAINT_TYPE = 'U';
    
    BEGIN
    IF UPPER(OPERATION) IN ('DROP', 'DISABLE') THEN
      IF FK THEN
        BEGIN
          FOR E IN R LOOP
            ST := 'ALTER TABLE ' || E.TABLE_NAME || ' ' || OPERATION || '
                  CONSTRAINT ' || E.CONSTRAINT_NAME;
            EXECUTE IMMEDIATE (ST);
            DBMS_OUTPUT.PUT_LINE(ST);
          END LOOP;
        END;
      END IF;
      IF PK THEN
        BEGIN
          FOR E IN R LOOP
            ST := 'ALTER TABLE ' || E.TABLE_NAME || ' ' || OPERATION || '
                  CONSTRAINT ' || E.CONSTRAINT_NAME;
            EXECUTE IMMEDIATE (ST);
            DBMS_OUTPUT.PUT_LINE(ST);
          END LOOP;
        END;
        BEGIN
          FOR E IN P LOOP
            ST := 'ALTER TABLE ' || E.TABLE_NAME || ' ' || OPERATION || '
                  CONSTRAINT ' || E.CONSTRAINT_NAME;
            EXECUTE IMMEDIATE (ST);
            DBMS_OUTPUT.PUT_LINE(ST);
          END LOOP;
        END;
      END IF;
      IF UK THEN
        BEGIN
          FOR E IN U LOOP
            ST := 'ALTER TABLE ' || E.TABLE_NAME || ' ' || OPERATION || '
                  CONSTRAINT ' || E.CONSTRAINT_NAME;
            EXECUTE IMMEDIATE (ST);
            DBMS_OUTPUT.PUT_LINE(ST);
          END LOOP;
        END;
      END IF;
    ELSIF UPPER(OPERATION) IN ('ENABLE') THEN
      IF PK THEN
        BEGIN
          FOR E IN P LOOP
            ST := 'ALTER TABLE ' || E.TABLE_NAME || ' ' || OPERATION || '
                  CONSTRAINT ' || E.CONSTRAINT_NAME;
            EXECUTE IMMEDIATE (ST);
            DBMS_OUTPUT.PUT_LINE(ST);
          END LOOP;
        END;
      END IF;
      IF FK THEN
        BEGIN
          FOR E IN P LOOP
            ST := 'ALTER TABLE ' || E.TABLE_NAME || ' ' || OPERATION || '
                  CONSTRAINT ' || E.CONSTRAINT_NAME;
            EXECUTE IMMEDIATE (ST);
            DBMS_OUTPUT.PUT_LINE(ST);
          END LOOP;
        END;
        BEGIN
          FOR E IN R LOOP
            ST := 'ALTER TABLE ' || E.TABLE_NAME || ' ' || OPERATION || '
                  CONSTRAINT ' || E.CONSTRAINT_NAME;
            EXECUTE IMMEDIATE (ST);
            DBMS_OUTPUT.PUT_LINE(ST);
          END LOOP;
        END;
      END IF;
      IF UK THEN
        BEGIN
          FOR E IN U LOOP
            ST := 'ALTER TABLE ' || E.TABLE_NAME || ' ' || OPERATION || '
                  CONSTRAINT ' || E.CONSTRAINT_NAME;
            EXECUTE IMMEDIATE (ST);
            DBMS_OUTPUT.PUT_LINE(ST);
          END LOOP;
        END;
      END IF;
    ELSE
      DBMS_OUTPUT.PUT_LINE('THE FIRST PARAMETER OF THE PROCEDURE MUST BE
                           DROP OR ENABLE OR DISABLE');
    END IF;
    END;

    2.过程执行

     

     第一个参数填disable,其它空,然后执行,成功后就愉快的执行导入语句了,最后别忘了启用;参数说明:disable=禁用,enable=启用

  • 相关阅读:
    构建自己的外汇智能交易系统
    EA范例
    读书札记:加拿大元因素
    预计欧元近期将“绝境大反攻”
    读书札记:新西兰元因素
    在新的一年里开启新的人生
    旧文重发:行在道上,从局部到全局——与师者高焕堂、赵善中先生谈《大道至简》
    与邹欣先生就《大道至简》一书中的两个主要问题的讨论
    《大道至简》一书第三版,与编辑就本书写作风格的讨论
    与读者们谈谈《大道至简》这五年
  • 原文地址:https://www.cnblogs.com/mwd-banbo/p/14075299.html
Copyright © 2020-2023  润新知