温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2020-08-11 23:07:18 来源:ITPUB博客 阅读:302 作者:xysoul_云龙 栏目:关系型数据库

问题:怎么使用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命令,表空间变小,可以为其他表空间分配空间了








向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI