`

Oracle跨版本导出EXP-00003错误的解决

阅读更多

【现象描述】:

      当Oracle数据库中,使用不同版本的exp工具进行数据库导出时,有时候会遇到类似如下错误:
      EXP-00003: no storage definition found for segment(11, 307)
      EXP-00003: no storage definition found for segment(11, 523)
      EXP-00003: no storage definition found for segment(11, 643)
      EXP-00003: no storage definition found for segment(11, 275)  

【原因分析】:
 "EXP-00003: no storage definition found for segment ....."错误,和Oracle的一个小Bug相关,可以通过修改一个导出相关的View来解决。
在目标数据库使用sys用户,执行如下SQL创建新的view:
CREATE OR REPLACE VIEW exu9tne (
tsno, fileno, blockno, length) AS
SELECT ts#, segfile#, segblock#, length
FROM sys.uet$
WHERE ext# = 1
UNION ALL
SELECT * FROM SYS.EXU9TNEB
/


【处理过程】:
 然后就可以正常进行导出操作,exp完成后, 最好将视图还原(Metalink建议):
CREATE OR REPLACE VIEW exu9tne (
tsno, fileno, blockno, length) AS
SELECT ts#, segfile#, segblock#, length
FROM sys.uet$
WHERE ext# = 1
/
EXU9TNE视图初始由 $ORACLE_HOME/rdbms/admin/catexp.sql 脚本创建。

 

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics