【TABLESPACE】怎么使用resize使表空间变小


问题:怎么使用resize使表空间变小  或者说怎么让表空间resize到一个合理的值,并且腾出部分空间


查看当前块(标准块)大小

点击(此处)折叠或打开

  1. SQL> set verify off
  2. SQL> column file_name format a50 word_wrapped
  3. SQL> column smallest format 999,990 heading "Smallest|Size|Poss."
  4. SQL> column currsize format 999,990 heading "Current|Size"
  5. SQL> column savings format 999,990 heading "Poss.|Savings"
  6. SQL> break on report
  7. SQL> compute sum of savings on report
  8. SQL>
  9. SQL> column value new_val blksize
  10. SQL> select value from v$parameter where name = 'db_block_size';

  11. VALUE
  12. --------------------------------------------------------------------------------
  13. 8192

查看某个表空间可以收缩多少空间


点击(此处)折叠或打开

  1. SQL> select file_name,
  2.   2 ceil( (nvl(hwm,1)*&&blksize)/1024/1024 ) smallest,
  3.   3 ceil( blocks*&&blksize/1024/1024) currsize,
  4.   4 ceil( blocks*&&blksize/1024/1024) -
  5.   5 ceil( (nvl(hwm,1)*&&blksize)/1024/1024 ) savings
  6.   6 from dba_data_files a,
  7.   7 ( select file_id, max(block_id+blocks+7) hwm
  8.   8 from dba_extents where tablespace_name='TEST'
  9.   9 group by file_id ) b
  10.  10 where a.file_id = b.file_id(+) and tablespace_name='TEST';

  11.                                                    Smallest
  12.                                                        Size Current Poss.
  13. FILE_NAME Poss. Size Savings
  14. -------------------------------------------------- -------- -------- --------
  15. /oracle/app/oracle/oradata/mydb/test01.dbf 139 2,048 1,909
  16. /backup/test02.dbf 36 1,024 988
  17.                                                                      --------
  18. sum 2,897  --可以腾出空间的总大小2897M

生成操作语句

点击(此处)折叠或打开

  1. SQL> column cmd format a75 word_wrapped
  2. SQL> select 'alter database datafile '''||file_name||''' resize ' ||
  3.   2 ceil( (nvl(hwm,1)*&&blksize)/1024/1024 ) || 'm;' cmd
  4.   3 from dba_data_files a,
  5.   4 ( select file_id, max(block_id+blocks+7) hwm
  6.   5 from dba_extents where tablespace_name='TEST'
  7.   6 group by file_id ) b
  8.   7 where b.file_id = a.file_id(+)
  9.   8 and ceil( blocks*&&blksize/1024/1024) -
  10.   9 ceil( (nvl(hwm,1)*&&blksize)/1024/1024 ) > 0;

  11. CMD
  12. ---------------------------------------------------------------------------
  13. alter database datafile '/backup/test02.dbf' resize 36m;
  14. alter database datafile '/oracle/app/oracle/oradata/mydb/test01.dbf' resize
  15. 139m


执行上述resize命令,表空间变小,可以为其他表空间分配空间了








来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29487349/viewspace-2143418/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29487349/viewspace-2143418/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值