北京华夏安泰技术论坛

 找回密码
 立即注册

扫一扫,访问微社区

QQ登录

只需要一步,快速开始

只需一步,快速开始

搜索
热搜: 活动 交友 discuz
查看: 456|回复: 0

oracle导入TYPE对象报错ORA-02304

[复制链接]

148

主题

202

帖子

1115

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1115
发表于 2017-8-4 14:57:49 | 显示全部楼层 |阅读模式
发现使用Type类型在数据exp/imp中的麻烦。当我们使用exp/imp工具进行同数据库实例(Instance)不同Schema之间数据拷贝时,如果Schema中有type类型,就会出现问题错误。

对于create type失败,可在导入命令中末尾加上 transform=OID:N
可以参考下面的说明。
大意就是说如果TRANSFORM参数设置成OID=N,表示在imp的时候,新创建的表或这个类型会赋予新的OID,而不是dmp文件中包含的OID的值。但是这个参数的默认值是OID=Y,因此在进行Imp的时候,新创建的表或者type会赋予同样的OID,如果是位于同一个数据库上的不同schema,那就会造成OID冲突的问题,因此解决这个问题也很简单,只需要在impdp的时候,显示设置transform 参数为OID=N既可以了。如下所示,

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

  1. IMP-00003: 遇到 ORACLE 错误 2304

  2. ORA-02304: 无效的对象标识符文字
  3. IMP-00017: 由于 ORACLE 错误 2304, 以下语句失败:

  4. "CREATE TYPE "T_REC_TABLE" TIMESTAMP '2010-12-21:18:17:33' OID 'D9AFD3FAE0A5"

  5. "4964B1684CA28C69CEED'   as table of t_rec_test;"

  6. ""

  7. ""

  8. IMP-00003: 遇到 ORACLE 错误 2304

  9. ORA-02304: 无效的对象标识符文字
  10. IMP-00017: 由于 ORACLE 错误 2304, 以下语句失败:

  11. "CREATE TYPE "T_TYP" TIMESTAMP '2012-03-07:10:47:03' OID '8E294AB7CC28493A94"

  12. "FF82791A376379'   as object (id number);"

  13. ""

  14. ""
复制代码


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册  

本版积分规则


小黑屋|手机版|Archiver|北京华夏安泰技术论坛  

GMT+8, 2019-3-21 23:49 , Processed in 0.093750 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表