oracle匯入TYPE物件報錯ORA-02304

資料與人發表於2021-04-06

Type是我們經常使用的資料庫物件結構。我們在實際中,可以單獨定義type型別,之後在PL/SQL程式碼或者資料表中使用。

 

在一個偶然的機會發現使用Type型別在資料exp/imp中的麻煩。

當我們使用exp/imp工具進行同資料庫例項(Instance)不同Schema之間資料複製時,

如果Schema中有type型別,就會出現問題錯誤。

 

如下:

 1 IMP-00003: 遇到 ORACLE 錯誤 2304
 2 
 3 ORA-02304: 無效的物件識別符號文字
 4 
 5 IMP-00017: 由於 ORACLE 錯誤 2304, 以下語句失敗:
 6 
 7  
 8 
 9  "CREATE TYPE "T_REC_TABLE" TIMESTAMP '2019-12-21:18:17:33' OID 'D9AFD3FAE0A5"
10 
11  "4964B1684CA28C69CEED'   as table of t_rec_test;"
12 
13  
14 
15 IMP-00003: 遇到 ORACLE 錯誤 2304
16 
17 ORA-02304: 無效的物件識別符號文字
18 
19 IMP-00017: 由於 ORACLE 錯誤 2304, 以下語句失敗:
20 
21  
22 
23  "CREATE TYPE "T_TYP" TIMESTAMP '2019-03-07:10:47:03' OID '8E294AB7CC28493A94"
24 
25  "FF82791A376379'   as object (id number);"

 

 

對於create type失敗,可在匯入命令中末尾加上 transform=OID:N

可以參考下面的說明。

 

大意就是說如果TRANSFORM引數設定成OID=N,表示在imp的時候,新建立的表或這個型別會賦予新的OID,

而不是dmp檔案中包含的OID的值。但是這個引數的預設值是OID=Y,因此在進行Imp的時候,

新建立的表或者type會賦予同樣的OID,如果是位於同一個資料庫上的不同schema,那就會造成OID衝突的問題,

因此解決這個問題也很簡單,只需要在impdp的時候,顯示設定transform 引數為OID=N既可以了。如下所示,

 

1  impdp test/test directory=dump_dir dumpfile=dump.dmp logfile=dump.log remap_schema=frank:test  transform=OID:N)

 


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

相關文章