oracle导入TYPE对象报错ORA-02304

当使用Oracle的exp/imp工具在不同Schema间复制数据时,如果涉及Type对象,可能会遇到ORA-02304错误。解决这个问题的方法是在impdp命令中添加transform=OID:N选项,这将确保在导入时为新创建的对象分配新的OID,避免与源Schema中的OID冲突。通过这样做,可以顺利地完成不同类型的数据迁移。
摘要由CSDN通过智能技术生成

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) 

 

聚焦技术与人文,分享干货,共同成长!

更多内容请关注“数据与人”

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值