对于大型数据库,Oracle占用的磁盘空间很是大,掌握数据库中那些用户、表占用了多杀磁盘空间,以及增加状况,能够方便往后对磁盘系统进行维护和扩充。数据库
对Oracle磁盘空间使用状况,能够分为按照表空间、用户或者表来进行统计。ui
(一)、表空间spa
计算表空间的剩余大小orm
或者索引
select tablespace_name, sum(bytes)/(1024*1024*1024) "SPACE(G)" from dba_free_space group by tablespace_name;(二)、用户资源
计算每一个用户占用的磁盘空间it
select owner,sum(bytes)/1024/1024/1024 "Space(G)" from dba_segments group by owner order by 2;计算某个用户占用的磁盘空间table
select owner,sum(bytes)/1024/1024/1024 "Space(G)" from dba_segments where owner='LIAOJL' group by owner;(三)、表form
Oracle都是以段为存储的,segment_name包含了表、索引、回滚段等,因此在dba_extents,dba_segments均可以找到占用空间大小的信息。class
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;