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=啟用

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM