欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-01-12 18:23:10
在给客户培训的过程中,发现客户数据库服务器存在一个奇怪的现象。客户数据库服务器环境为aix6+oracle11gr2,具体现象如下: 执行exp导出时,部分表提示 exp...

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