linux+oracle磁盘空间,Oracle磁盘空间使用统计

对于大型数据库,Oracle占用的磁盘空间非常大,掌握数据库中那些用户、表占用了多杀磁盘空间,以及增长情况,可以方便日后对磁盘系统进行维护和扩充。

对Oracle磁盘空间使用情况,可以分为按照表空间、用户或者表来进行统计。

(一)、表空间

计算表空间的剩余大小

select A.TABLESPACE_NAME,A.BYTES/(1024*1024*1024) "SPACE(G)",

C.BYTES/(1024*1024) "FREE SPACE(M)",(C.BYTES*100)/A.BYTES "% FREE"

FROM SYS.SM$TS_AVAIL A,SYS.SM$TS_FREE C

WHERE A.TABLESPACE_NAME=C.TABLESPACE_NAME;

或者

select tablespace_name, sum(bytes)/(1024*1024*1024) "SPACE(G)"

from dba_free_space

group by tablespace_name;

(二)、用户

计算每个用户占用的磁盘空间

select owner,sum(bytes)/1024/1024/1024 "Space(G)"

from dba_segments

group by owner

order by 2;

计算某个用户占用的磁盘空间

select owner,sum(bytes)/1024/1024/1024 "Space(G)"

from dba_segments

where owner='LIAOJL'

group by owner;

(三)、表

Oracle都是以段为存储的,segment_name包含了表、索引、回滚段等,所以在dba_extents,dba_segments都可以找到占用空间大小的信息。

select sum(bytes)/1024/1024 "Space(M)"

from dba_extents

where owner='LIAOJL' and segment_name='STUDENTS';

dba_segments也可以计算表的大小:

select segment_name,bytes/1024/1024 "Space(MB)"

from dba_segments

where SEGMENT_TYPE='TABLE' and segment_name=upper('你要查找的表的名字');

当时上面的写法不完全正确,当表是分区表,dba_segments有多条信息,可改成:

select segment_name,sum(bytes)/1024/1024 "Space(MB)"

from dba_segments

where segment_name=upper('你要查找的表的名字');

上述方法对于一个很大的数据库,SQL语句执行起来会很慢,而且消耗数据库资源。Oracle支持对表进行分析,执行分析表操作后可以在dba_tables等系统表中查询表大小、行数等信息,不过这些信息不是实时更新的,可以在数据库空闲时,通过计划任务来更新。

分析SQL方法:

analyze   table   tab_name   compute   statistics;

表太大的话可以执行:

analyze   table   tab_name   estimate   statistics;0b1331709591d260c1c78e86d0c51c18.png

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值