• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    oracle11gR2使用exp导出命令时报EXP-00011错误的解决方法

    在给客户培训的过程中,发现客户数据库服务器存在一个奇怪的现象。客户数据库服务器环境为AIX6+Oracle11gR2,具体现象如下:

    执行EXP导出时,部分表提示 EXP-00011:表不存在错误,但是查询user_all_tables视图,此表确实是存在的,并且执行select语句也能成功,不过表为空表,查看权限等也没有问题。后来通过查询资料,发现问题是由Deferred Segment Creation参数引起的。

    Deferred Segment Creation,延迟段创建,Oracle11gR2新增参数, 具体用处是当新创建一个可能会有Segment的对象时,如果这个对象中还没有任何记录需要消耗一个Extent,那么将不会在创建对象时自动创建Segment,这样做的好处是在创建对象时大大提高了速度。但是这么一来,因为对象没有Segment,执行EXP导出时,就会报EXP-00011错误。

    以报错的表cf_template为例,执行以下查询:

    复制代码 代码如下:

    SQL> show parameter DEFERRED_SEGMENT_CREATION

     

    NAME                                 TYPE                 VALUE

    ------------------------------------ -------------------- --------------------

    deferred_segment_creation            boolean              TRUE

    发现Deferred Segment Creation已经打开,再执行:

    复制代码 代码如下:

    SQL> select segment_name from user_segments where segment_name='CF_TEMPLATE';

    no rows selected

    没有返回值,数据库确实没有给CF_TEMPLATE表创建Segment,这就验证了为什么报错的都是空表。

    解决方法如下:

    1.  设置deferred_segment_creation的值为false

    此方法只对以后的表有效,之前的表没有Segment的还是没有。

    2.  创建表的时候声明立即创建Segment

    create table XXX (XXX  XXX) SEGMENT CREATION IMMEDIATE;

    3.对于已经创建但是还没有Segment的表来说,可以执行alter table XXX allocate extent来使其创建出     Segment,当然也可以插入一条数据,使其创建Segment

    您可能感兴趣的文章:
    • Centos下Oracle11gR2安装教程与自动化配置脚本的方法
    • centos7下安装oracle11gR2的详细步骤
    • linux系统下oracle11gR2静默安装的经验分享
    • Oracle11g r2 卸载干净重装的详细教程(亲测有效已重装过)
    • Oracle11g R2 安装教程完整版
    上一篇:登录oracle数据库时密码忘记的解决方法
    下一篇:oracle分页存储过程 oracle存储过程实例
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    oracle11gR2使用exp导出命令时报EXP-00011错误的解决方法 oracle11gR2,使用,exp,导出,