zoukankan      html  css  js  c++  java
  • oracle导入TYPE对象报错ORA-02304

    Type是我们经常使用的数据库对象结构。我们在实际中,可以单独定义type类型,之后在PL/SQL代码或者数据表中使用。

     

    在一个偶然的机会让笔者发现使用Type类型在数据exp/imp中的麻烦。当我们使用exp/imp工具进行同数据库实例(Instance)不同Schema之间数据拷贝时,如果Schema中有type类型,就会出现问题错误。

    如下:

    IMP-00003: 遇到 ORACLE 错误 2304
    
    ORA-02304: 无效的对象标识符文字
    IMP-00017: 由于 ORACLE 错误 2304, 以下语句失败:
    
     "CREATE TYPE "T_REC_TABLE" TIMESTAMP '2010-12-21:18:17:33' OID 'D9AFD3FAE0A5"
    
     "4964B1684CA28C69CEED'   as table of t_rec_test;"
    
     ""
    
     ""
    
    IMP-00003: 遇到 ORACLE 错误 2304
    
    ORA-02304: 无效的对象标识符文字
    IMP-00017: 由于 ORACLE 错误 2304, 以下语句失败:
    
     "CREATE TYPE "T_TYP" TIMESTAMP '2012-03-07:10:47:03' OID '8E294AB7CC28493A94"
    
     "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既可以了。如下所示,

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

    参考地址:http://www.shangxueba.com/jingyan/View.aspx?id=52990

    http://blog.itpub.net/17203031/viewspace-732089/

    感谢

  • 相关阅读:
    你爱的不爱你,转身是幸福
    按字节长度截取字符串(支持截取带HTML代码样式的字符串)
    存储过程操作类
    C# 拖动控件
    文件同步类
    c# 动态改变控件大小的方法
    虚拟世界改变现实 盛大兴建永恒之塔
    c#百钱买百鸡
    序列化类
    DLL专题之MFC规则库和扩展库
  • 原文地址:https://www.cnblogs.com/no27/p/4281111.html
Copyright © 2011-2022 走看看