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

作者:eygle | English Version 【转载时请以超链接形式标明文章出处和作者信息及本声明】
链接:http://www.eygle.com/archives/2009/02/oracle_exp_00003.html

站内相关文章|Related Articles
  • Logical Standby ORA-01425错误处理一则
  • Oracle 10.2.0.3的Ora-1461 / Smg-3500错误
  • ORA-07445 kprball()+483错误之原因分析
  • ORA-600 kcbgtcr_13 未解决之问题记录
  • BUG带来的BUG-kjdrpkey2hv: called with pkey
  • 当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 脚本创建。

    -The End-

    你可能感兴趣的:(oracle,sql,数据库,脚本,工具)