导出数据时,空表报错。
解决方法如下:
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
终极方法:
先查询一下哪些表是空的:
Sql代码
select table_name from user_tables where NUM_ROWS=0;
下面我们通过select 来生成修改语句:
Sql代码
select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0
ok 执行上面那些sql,之后再exp吧,那就是见证奇迹的深刻。
http://www.2cto.com/database/201109/105931.html作者“那一夜未眠”