oracle中和表空间、数据文件有关的视图经常会用到,今天总结一下,常用的视图如下:
1、DBA_TABLESPACES
记录了表空间的基本信息,重要字段有status(online、offline、read only),contents(undo、permanent、temporary)、EXTENT_MANAGEMENT(一般为local)、 SEGMENT_SPACE_MANAGEMENT(manual和auto)
2、DBA_DATA_FILES 
记录了具体数据文件的信息,重要字段有file_name,tablespace_name,bytes,blocks, AUTOEXTENSIBLE
从此表中,可以得出所有数据文件(不包括临时表空间)的大小
SQL> select sum(blocks*8192/1024/1024/1024)||'G'  from dba_data_files ;
SUM(BLOCKS*8192/1024/1024/1024)||'G'
-----------------------------------------
22.880859375G
3、DBA_TEMP_FILES
如果要得到临时表空间的大小,可以从DBA_TEMP_FILES中获取

SQL> select file_name,status,blocks*8192/1024/1024/1024||'G' from dba_temp_files;
FILE_NAME                                STATUS    BLOCKS*8192/1024/1024/1024||'G'
---------------------------------------- --------- -----------------------------------------
/home5/oradata/riji/temp02.dbf           AVAILABLE 18.06640625G
综合DBA_DATA_FILES和DBA_TEMP_FILES,可以得到所有表空间的总大小。
select
(
 (select sum(blocks*8192/1024/1024/1024) from dba_data_files)
  +
  (select sum(blocks*8192/1024/1024/1024) from dba_temp_files)
 )
  as total_size
  from dual;
例如:
SQL> select
  2  (
  3  (select sum(blocks*8192/1024/1024/1024) from dba_data_files)
  4  +
  5  (select sum(blocks*8192/1024/1024/1024) from dba_temp_files)
  6  )
  7  as total_size
  8  from dual;
TOTAL_SIZE
----------
40.9472656
4、DBA_FREE_SPACE 
记录了每个表空间中的各个数据文件目前可用空间(没有考虑扩展)。重要字段有tablespace_name,file_id,blocks,block_id(extent的起始块号)。
例如,计算当前各个表空间的可用空间sql如下:
SQL> select tablespace_name, sum(blocks*8192/1024/1024/1024)||' G' free_space from dba_free_space group by tablespace_name;
TABLESPACE_NAME                FREE_SPACE
------------------------------ ------------------------------------------
INDXNEW                        1.21160888671875 G
PERFSTAT                       .00994873046875 G
SYSTEM                         .32708740234375 G
UNDOTBS                        .548095703125 G
USERS                          1.2169189453125 G
YPAGE                          1.943359375 G
6 rows selected.
 
如果想具体到某个数据文件的目前可用空间,sql如下:
SQL> l
  1*  select tablespace_name,file_id,sum(blocks*8192/1024/1024/1024)||' G' free_space from dba_free_space group by tablespace_name,file_id
SQL> /
TABLESPACE_NAME                   FILE_ID FREE_SPACE
------------------------------ ---------- ------------------------------------------
USERS                                   2 1.2169189453125 G
YPAGE                                   5 .0665283203125 G
YPAGE                                   6 1.84368896484375 G
YPAGE                                   9 .03314208984375 G
SYSTEM                                  1 .32708740234375 G
INDXNEW                                 3 1.21160888671875 G
UNDOTBS                                 4 .00189208984375 G
UNDOTBS                                 7 .54620361328125 G
PERFSTAT                               11 .00994873046875 G
9 rows selected.
但是一定要注意,这里的空间是指当前实际空间,如果数据文件可以扩展,则剩余空间的size应该从DBA_DATA_FILE中取得。
SQL> select tablespace_name,sum((maxblocks-blocks)*8192/1024/1024/1024) ||' G' free_size from dba_data_files group by tablespace_name;
TABLESPACE_NAME                FREE_SIZE
------------------------------ ------------------------------------------
INDXNEW                        27.1171722412109375 G
PERFSTAT                       29.1874847412109375 G
SYSTEM                         31.5117034912109375 G
UNDOTBS                        3.28125 G
USERS                          27.9687347412109375 G
YPAGE                          89.9491729736328125 G
 
 5  、DBA_TABLES
记录了表的基本信息,和空间相关的主要有num_rows、blocks、empty_blocks、avg_space等,此视图中的这些参数需要通过分析命令才可以得到:
exec dbms_stats.gather_table_stats(ownname=>'username',tabname=>'tablename',ESTIMATE_PERCENT=>30,cascade=>true);
可以根据里面的blocks大致估计表的size:
  SQL> select sum(BLOCKS*8192/1024/1024) from dba_tables where table_name='YP_CORP_INFO';
SUM(BLOCKS*8192/1024/1024)
--------------------------
                880.695313
6、DBA_TAB_PARTITIONS
记录了表分区的基本信息,主要信息和DBA_TABLES类似,下面显示了表order_tab每个分区的size信息
SQL> select table_name,partition_name,subpartition_count ,tablespace_name,blocks*8192/1024/1024 as partition_size  from dba_tab_partitions WHERE table_name='ORDER_TAB';
TABLE_NAME                     PARTITION_NAME                 SUBPARTITION_COUNT TABLESPACE_NAME                PARTITION_SIZE
------------------------------ ------------------------------ ------------------ ------------------------------ --------------
ORDER_TAB                      POD0                                            4 TOD0                               3773.34375
ORDER_TAB                      POD1                                            4 TOD1                               619.117188
ORDER_TAB                      POD2                                            4 TOD2                                737.78125
ORDER_TAB                      POD3                                            4 TOD3                               868.117188
ORDER_TAB                      POD4                                            4 TOD4                                 .0078125
ORDER_TAB                      POD5                                            4 TOD5                                 .0078125
ORDER_TAB                      POD6                                            4 TOD6                                 .0078125
ORDER_TAB                      POD7                                            4 TOD7                                 .0078125
ORDER_TAB                      POD8                                            4 TOD8                                 .0078125
 
 7、DBA_TAB_SUBPARTITIONS
和DBA_TAB_PARTITIONS类似,下面记录了pod0下面的子分区信息: