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;
再导出改表即可!

解决方案 »

  1.   

    这个要算是oracle的bug吧
      

  2.   


    这个不是 bug ,是一个新特性。 也就是说特意做成这样了。目的是为了更快的响应 create table 命令。
      

  3.   

    当然是bug。我并不是说这个新特性有问题,为了更快影响create table在建表时不分配空间是合理的,不过这个新特性需要考虑对其它功能的影响,现在它影响到了备份,这其实是个很严重的bug。莫非oracle特意让备份出问题?
      

  4.   

    这个怎么能说是BUG…… oracle明确这个特性带来的影响,并给出了解决方法,而且10g以后oracle就推荐用数据泵了,当然非要说BUG也行,但在这个时代,Oracle有时间去修改这种代码,还不如多多解决rman备份时候的BUG,毕竟这个才算是真正的备份,逻辑备份工具只是辅助而已。
      

  5.   

    完全正确 应该使用 expdp
      

  6.   

    执行一下这个SQL:
    Select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0 or num_rows is null;
    把查询出来的结果贴出来执行一下就可以了