联奕科技工程体系

 找回密码
 立即注册
查看: 164|回复: 0

【Oracle】Oracle 11g导出空表、少表的解决办法

[复制链接]

12

主题

18

帖子

2269

积分

金牌会员

Rank: 6Rank: 6

积分
2269
发表于 2018-12-27 10:58:49 | 显示全部楼层 |阅读模式

ORACLE 11G中有个新特性,当表无数据时,不分配segment,以节省空间。

解决方法:
  1)insert一行,再rollback就产生segment了
  该方法是在在空表中插入数据,再删除,则产生segment。导出时则可导出空表。
  
     2)设置deferred_segment_creation参数
              SQL> show parameter deferred_segment_creation NAME                                 TYPE        VALUE ------------------------------------ ----------- ------------------------------ deferred_segment_creation            boolean     TRUE               SQL> alter system set deferred_segment_creation=false; 系统已更改。
              SQL> show parameter deferred_segment_creation NAME                                 TYPE        VALUE ------------------------------------ ----------- ------------------------------ deferred_segment_creation            boolean     FALSE
  需注意的是:该值设置后对以前导入的空表不产生作用,仍不能导出,只能对后面新增的表产生作用。如需导出之前的空表,只能用第一种方法。
      
    3)批量处理空表
       首先使用下面的sql语句查询一下当前用户下的所有空表
              select table_name from user_tables where NUM_ROWS=0;

  然后用一下SQL语句执行查询
             select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0
  假设我们这里有空表TBL_1,TBL_2,TBL_3,TBL_4,则查询结果如下:
             alter table TBL_1 allocate extent;
             alter table TBL_2 allocate extent;
             alter table TBL_3 allocate extent;
             alter table TBL_4 allocate extent;

  最后我们把上面的SQL语句执行就可以了。




One More Time ! Q_Q
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|ly-sky.com

GMT+8, 2025-12-18 00:09 , Processed in 0.104714 second(s), 19 queries .

快速回复 返回顶部 返回列表