oracle导入TYPE对象报错ORA-02304
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)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了