继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Oracle中和空间有关的视图总结(1)

PIPIONE
关注TA
已关注
手记 1117
粉丝 149
获赞 703


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下面的子分区信息:

©著作权归作者所有:来自51CTO博客作者帅小伙的原创作品,如需转载,请注明出处,否则将追究法律责任

Oracle空间视图oracle


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP