【備份語句】
導出語句: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 106 列 2 1 列 3 bpmn/GroupCivilizationCommittee.png 列 4 105 列 5 00780001010C080000010000000100001246D573000376DA00... 列 6 0 IMP-00019: 由於 ORACLE 錯誤 2291 而拒絕行 IMP-00003: 遇到 ORACLE 錯誤 2291 ORA-02291: 違反完整約束條件 (ACTIVITI.ACT_FK_BYTEARR_DEPL) - 未找到父項關鍵字 列 1 107 列 2 1 列 3 bpmn/GroupCivilizationCommittee.bpmn20.xml 列 4 105 列 5 006C0001010C080000010000000100001246D574000376DA00... 列 6 0 IMP-00019: 由於 ORACLE 錯誤 2291 而拒絕行 IMP-00003: 遇到 ORACLE 錯誤 2291 ORA-02291: 違反完整約束條件 (ACTIVITI.ACT_FK_BYTEARR_DEPL) - 未找到父項關鍵字 列 1 110 列 2 1 列 3 bpmn/GroupOrgPartyCommittee.bpmn20.xml 列 4 109 列 5 006C0001010C080000010000000100001246D575000376DA00... 列 6 0 IMP-00019: 由於 ORACLE 錯誤 2291 而拒絕行 IMP-00003: 遇到 ORACLE 錯誤 2291 ORA-02291: 違反完整約束條件 (ACTIVITI.ACT_FK_BYTEARR_DEPL) - 未找到父項關鍵字 列 1 111 列 2 1 列 3 bpmn/GroupOrgPartyCommittee.png 列 4 109 列 5 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=啟用