空娅芬 发表于 2025-12-4 00:35:00

expdp dmp 导出不完整导入ORA-39059 ORA-39246 故障抢救数据

客户一套nc系统,由于安装时候把库建在了比较小的分区上,运行一些时间之后,出现空间不足,现场技术人员对oracle不太熟悉,经过一系列操作(删除业务表空间,复制pdb,创建表空间等等操作),无法恢复数据库,准备使用备份的dmp进行还原,结果分析发现仅保留的最后一份dmp,是一份导出不完全的dmp文件,无法正常导入(以前处理过一个类似case:ORA-39773: parse of metadata stream failed故障处理,尝试导入报ORA-39246错:
C:\Users\XFF>impdp system/oracle@127.0.0.1/orapdb directory=expdp_dir dumpfile=xxxxx_2025-12-01_0230.dmp logfile=1.log Import: Release 19.0.0.0.0 - Production on 星期三 12月 3 21:00:19 2025Version 19.3.0.0.0 Copyright (c) 1982, 2019, Oracle and/or its affiliates.  All rights reserved. 连接到: Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - ProductionORA-39002: 操作无效ORA-39059: 转储文件集不完整ORA-39246: 无法在提供的转储文件中定位主表分析当时当初的dmp日志,由于expdp的job表所在表空间不足导致expdp导出失败

TABLE:"XIFENFEI"."EOM_MEASURE_POINT"ORA-30032: 挂起的 (可恢复) 语句已超时ORA-01691: Lob 段 XIFENFEI.SYS_LOB0000161267C00111$$ 无法通过 32 (在表空间 NNC_DATA01 中) 扩展ORA-06512: 在 "SYS.DBMS_SYS_ERROR", line 105ORA-06512: 在 "SYS.KUPW$WORKER", line 12620ORA-06512: 在 "SYS.DBMS_SYS_ERROR", line 105ORA-06512: 在 "SYS.KUPW$WORKER", line 11414----- PL/SQL Call Stack -----  object      line  object  handle    number  name0xda5dae50     33476  package body SYS.KUPW$WORKER.WRITE_ERROR_INFORMATION0xda5dae50     12641  package body SYS.KUPW$WORKER.DETERMINE_FATAL_ERROR0xda5dae50     11602  package body SYS.KUPW$WORKER.CREATE_OBJECT_ROWS0xda5dae50     15268  package body SYS.KUPW$WORKER.FETCH_XML_OBJECTS0xda5dae50      3907  package body SYS.KUPW$WORKER.UNLOAD_METADATA0xda5dae50     13736  package body SYS.KUPW$WORKER.DISPATCH_WORK_ITEMS0xda5dae50      2429  package body SYS.KUPW$WORKER.MAIN0x6524a4f0         2  anonymous blockKUPW: Object row index into parse items is: 1KUPW: Parse item count is: 19KUPW: In function CHECK_FOR_REMAP_NETWORKKUPW: Nothing to remapKUPW: In procedure BUILD_OBJECT_STRINGS - non-base infoKUPW: In procedure BUILD_SUBNAME_LIST with TABLE:XIFENFEI.EOM_MEASURE_POINTKUPW: In function NEXT_PO_NUMBERKUPW: PO number assigned: 34198FORALLKUPW: In procedure DETERMINE_FATAL_ERROR with ORA-30032: 挂起的 (可恢复) 语句已超时ORA-01691: Lob 段 XIFENFEI.SYS_LOB0000161267C00111$$ 无法通过 32 (在表空间 NNC_DATA01 中) 扩展作业 "XIFENFEI"."SYS_EXPORT_SCHEMA_01" 因致命错误于 星期一 12月 1 06:33:21 2025 elapsed 0 04:03:18 停止从导出日志看,在导出大量”0 KB 0 行”记录之后提示表空间不足,expdp的job表无法扩展导致导出挂起然后超时导出终止(这个导出操作没有完全完成),从而在导入的时候出现了ORA-39059: 转储文件集不完整 ORA-39246: 无法在提供的转储文件中定位主表 的错误.对于这种故障,分析导出日志,发现运气不错,所有有数据的表都导出完成,基于这个心中就有了第一层底气,所有表数据不会丢失(因为都导出到了这个dmp中),但是非表的字典数据不完整,要想业务完整跑起来,需要找到一个完整的业务字典信息.对于大量的备份dmp被删除,然后对应分区还写入了很多数据,只能尝试看运气,通过对磁盘文件镜像,然后进行反删除恢复,找出来一个11月26日的dmp的压缩文件是完整的

通过这个dmp导入业务字典信息,然后再利用expdp dmp解析工具(expdp dmp被加密破坏恢复)把所有表数据出来,经过这两者组合,顺利完成数恢复,可以测试业务完全正常 

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

砂歹汤 发表于 2025-12-17 08:18:47

懂技术并乐意极积无私分享的人越来越少。珍惜

吕梓美 发表于 2026-1-3 07:31:32

感谢,下载保存了

彭水晶 发表于 2026-1-18 07:43:50

喜欢鼓捣这些软件,现在用得少,谢谢分享!

祖娅曦 发表于 2026-1-19 23:53:49

这个好,看起来很实用

岑韬哎 发表于 2026-1-21 07:55:55

谢谢分享,试用一下

啤愿 发表于 2026-1-22 11:52:18

感谢分享,下载保存了,貌似很强大

哈妙思 发表于 2026-1-22 12:59:27

热心回复!

扫恢怯 发表于 2026-1-23 03:25:27

谢谢楼主提供!

格恳绌 发表于 2026-1-24 09:34:17

这个有用。

旌磅箱 发表于 2026-1-24 10:26:23

懂技术并乐意极积无私分享的人越来越少。珍惜

旌磅箱 发表于 2026-1-25 12:34:58

喜欢鼓捣这些软件,现在用得少,谢谢分享!

仟仞 发表于 2026-1-27 05:38:27

收藏一下   不知道什么时候能用到

支智敏 发表于 2026-1-27 07:08:06

这个有用。

柏雅云 发表于 2026-1-28 21:52:41

收藏一下   不知道什么时候能用到

梦霉 发表于 2026-1-29 03:53:54

感谢发布原创作品,程序园因你更精彩

卜笑 发表于 2026-1-30 02:32:54

懂技术并乐意极积无私分享的人越来越少。珍惜

挺喽蹂 发表于 2026-2-2 04:39:39

新版吗?好像是停更了吧。

国语诗 发表于 2026-2-4 07:38:55

新版吗?好像是停更了吧。

汪之亦 发表于 2026-2-5 05:34:29

喜欢鼓捣这些软件,现在用得少,谢谢分享!
页: [1] 2
查看完整版本: expdp dmp 导出不完整导入ORA-39059 ORA-39246 故障抢救数据