Oracle跨版本匯出EXP-00003錯誤的解決()

imlihj2007發表於2010-07-08

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 指令碼建立。

[@more@]在網上找找,說是因為用低版本導高版本資料庫資料造成的,將compress=y就可以解決,試了compress=y後,順利匯出。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/9879835/viewspace-1035079/,如需轉載,請註明出處,否則將追究法律責任。

相關文章