1.为什么会出现该问题racle 11g中有个新特性,当表无数据时,不分配segment,以节省空间,当我们用exp导出空表时,无法导出。解决方法是两个方面,一是处理现有的空表,让其能导出;二是设置参数,让后续的新的空表也可以导出。
2.解决方法
1.)在建用户时处理该问题!
设置系统参数,让后续新表自动分配segment,查询系统参数,该参数值默认是TRUE,当改为FALSE时,无论是空表还是非空表,都分配segment.
查询语句:show parameter deferred_segment_creation;将这个参数修改为FALSE,修改语句为:
alter system set deferred_segment_creation=false;再次查询确认参数是否修改成功:
show parameter deferred_segment_creation;再执行导出问题已解决!2.之前未修改空表参数,后续使用中发现个别空表无法导出。登录当前需导出的用户,执行以下语句
alter table 空表表明 allocate extend;
再导出改表即可!
2.解决方法
1.)在建用户时处理该问题!
设置系统参数,让后续新表自动分配segment,查询系统参数,该参数值默认是TRUE,当改为FALSE时,无论是空表还是非空表,都分配segment.
查询语句:show parameter deferred_segment_creation;将这个参数修改为FALSE,修改语句为:
alter system set deferred_segment_creation=false;再次查询确认参数是否修改成功:
show parameter deferred_segment_creation;再执行导出问题已解决!2.之前未修改空表参数,后续使用中发现个别空表无法导出。登录当前需导出的用户,执行以下语句
alter table 空表表明 allocate extend;
再导出改表即可!
这个不是 bug ,是一个新特性。 也就是说特意做成这样了。目的是为了更快的响应 create table 命令。
Select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0 or num_rows is null;
把查询出来的结果贴出来执行一下就可以了