zoukankan      html  css  js  c++  java
  • 数据泵导入外键表数据报错

    对一个业务用户数据使用数据泵迁移至另一个数据库,检查日志发现导入报错;

    [oracle@ora19cr3-n1 dmp]$ cat mxsystem514_202005142.log|grep ORA
    ORA-02291: integrity constraint (MXSYSWSGW.JOB_EXEC_PARAMS_FK) violated - parent key not found
    ORA-31693: Table data object "MXSYSWSGW"."WORKPLANRECEIVESCOPE" failed to load/unload and is being skipped due to error:
    ······
    由于有些表之间是存在主外键关联的,expdp导出的时候选择了data_only仅导出数据,impdp导入的时候会因未插入主键记录而插入外键记录,出现ORA-02291的错误,
    对于这种情况可以选择先禁止主外键关联,导入后再恢复关联。
    select owner,CONSTRAINT_NAME,CONSTRAINT_TYPE,TABLE_NAME,R_OWNER,R_CONSTRAINT_NAME,STATUS,INVALID,VIEW_RELATED from
    dba_constraints WHERE CONSTRAINT_TYPE='R' and owner='Mxx' AND TABLE_NAME IN('XXX'); OWNER CONSTRAINT_NAME C TABLE_NAME R_OWNER R_CONSTRAINT_NAME STATUS ---------- ------------------------------ - ------------------------------ ---------- -------------------- -------- Mxx Sxx_FK R BxxXT MXxxGW SYS_C0013343 ENABLED
    禁用外键约束
    select
    'ALTER TABLE MXSYSWSGW.'||TABLE_NAME||' DISABLE CONSTRAINT '||constraint_name||';'
    from dba_constraints WHERE CONSTRAINT_TYPE='R' and owner='Mxx' AND TABLE_NAME IN('xxx');
    启用外键约束【仅对新加入的数据强制执行约束,而不管表中的现有数据】
    select 'ALTER TABLE MXSYSWSGW.'||TABLE_NAME||' ENABLE NOVALIDATE CONSTRAINT '||constraint_name||';'
    from dba_constraints WHERE CONSTRAINT_TYPE='R' and owner='Mxx' AND TABLE_NAME IN('xxx');
    再次导入

    impdp xx/xx@mlxg directory=local_dmp dumpfile=xx%U_202005142.dmp logfile=xx_202005142.log parallel=4 cluster=no remap_schema="c##mlxg":QQSYSTEM content=data_only TABLE_EXISTS_ACTION=append TABLES="C##MLXG".XX

  • 相关阅读:
    Android项目打包
    Video Demystified
    C指针与python bytes 互转
    运筹学笔记 3 线性代数基础
    三角网格上的寻路算法Part.2—A*算法
    三角网格上的寻路算法Part.1—Dijkstra算法
    从二维点集重建平面形状-浅议凹包算法
    二值图像膨胀腐蚀算法的几种实现方式
    浅议像素化与体素化Part.1——平面图形像素化
    寻找图像中的局部极大点
  • 原文地址:https://www.cnblogs.com/lvcha001/p/12919150.html
Copyright © 2011-2022 走看看