度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 3929|回复: 1
打印 上一主题 下一主题

[分享] oracle11g使用exp导出命令时报EXP-00011错误的解决方法

[复制链接]

348

主题

3572

帖子

9724

积分

论坛元老

Rank: 8Rank: 8

积分
9724
跳转到指定楼层
楼主
发表于 2020-6-26 07:33:52 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
具体现象如下:
执行EXP导出时,部分表提示 EXP-00011:表不存在错误,但是查询user_all_tables视图,此表确实是存在的,并且执行select语句也能成功,不过表为空表,查看权限等也没有问题。后来通过查询资料,发现问题是由Deferred Segment Creation参数引起的。


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

  2. NAME                                 TYPE                 VALUE
  3. ------------------------------------ -------------------- --------------------
  4. deferred_segment_creation            boolean              TRUE
复制代码

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

  1. SQL> select segment_name from user_segments where segment_name='CF_TEMPLATE';
  2. 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

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复

使用道具 举报

348

主题

3572

帖子

9724

积分

论坛元老

Rank: 8Rank: 8

积分
9724
沙发
 楼主| 发表于 2020-7-19 22:17:07 | 只看该作者
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复 支持 反对

使用道具 举报

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

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-4-29 03:59 , Processed in 0.121148 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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