欢迎阅读『oracle exp方式导出的dmp备份文件,imp 方式导入主外键约束问题处理』
斑驳。
codeing or artist ?
posts - 37,comments - 8,views - 11万

【备份语句】

导出语句: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=启用

 

posted on   斑驳。  阅读(1427)  评论(3编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示