加入收藏 | 设为首页 | 会员中心 | 我要投稿 东莞站长网 (https://www.0769zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

oracle11gR2使用exp导出命令时报EXP-00011错误的解决措施

发布时间:2021-11-26 18:57:33 所属栏目:教程 来源:互联网
导读:在给客户培训的过程中,发现客户数据库服务器存在一个奇怪的现象。客户数据库服务器环境为AIX6+Oracle11gR2,具体现象如下: 执行EXP导出时,部分表提示 EXP-00011:表不存在错误,但是查询user_all_tables视图,此表确实是存在的,并且执行select语句也能成功

在给客户培训的过程中,发现客户数据库服务器存在一个奇怪的现象。客户数据库服务器环境为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

(编辑:东莞站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读