傳統的SQL腳本查看錶空間使用率,使用的關鍵視DBA_DATA_FILE和DBA_FREE_SPACE。Oracle 11g引入了DBA_TABLESPACE_USAGE_METRICS視圖。事實上,Oracle 10g中就已經引入了該視圖,可以使用,但在10g官方文檔中查不到,11g官方文檔對該視圖作了說明。
Oracle 11g 官方文檔中對DBA_TABLESPACE_USAGE_METRICS視圖的說明:
DBA_TABLESPACE_USAGE_METRICS describes tablespace usage metrics for all types of tablespaces,including permanent,temporary,and undo tablespaces.
Column |
Datatype |
NULL |
Description |
TABLESPACE_NAME |
VARCHAR2(30) |
|
Tablespace name |
USED_SPACE |
NUMBER |
|
Total space consumed by the tablespace,in database blocks |
TABLESPACE_SIZE |
NUMBER |
|
Total size of the tablespace,in database blocks |
USED_PERCENT |
NUMBER |
|
Percentage of used space,as a function of the maximum possible tablespace size |
從官網的說明來看,通過視圖DBA_TABLESPACE_USAGE_METRICS可以很方便的查看各類型表空間的使用情況,包括永久、臨時和undo表空間。但是,通過這個視圖查詢到的結果,和傳統的SQL腳步查詢到的結果不一致,而且相差很大。
看一下DBA_TABLESPACE_USAGE_METRICS視圖的定義語句:
select text from dba_views where view_name='DBA_TABLESPACE_USAGE_METRICS';
TEXT
-----------------------------------------------------------------
SELECT t.name, sum(f.allocated_space), sum(f.file_maxsize),
(sum(f.allocated_space)/sum(f.file_maxsize))*100
FROM sys.ts$ t, v$filespace_usage f
WHERE
t.online$ != 3 and
t.bitmapped <> 0 and
t.contents$ = 0 and
bitand(t.flags, 16) <> 16 and
t.ts# = f.tablespace_id
GROUP BY t.name, f.tablespace_id
union
SELECT t.name, sum(f.allocated_space), sum(f.file_maxsize),
(sum(f.allocated_space)/sum(f.file_maxsize))*100
FROM sys.ts$ t, v$filespace_usage f
WHERE
t.online$ != 3 and
t.bitmapped <> 0 and
t.contents$ <> 0 and
f.flag = 6 and
t.ts# = f.tablespace_id
GROUP BY t.name, f.tablespace_id
union
SELECT t.name, sum(f.allocated_space), sum(f.file_maxsize),
(sum(f.allocated_space)/sum(f.file_maxsize))*100
FROM sys.ts$ t, gv$filespace_usage f, gv$parameter param
WHERE
t.online$ != 3 and
t.bitmapped <> 0 and
f.inst_id = param.inst_id and
param.name = 'undo_tablespace' and
t.name = param.value and
f.flag = 6 and
t.ts# = f.tablespace_id
GROUP BY t.name, f.tablespace_id
-----------------------------------------------------------------
可以看出,DBA_TABLESPACE_USAGE_METRICS查詢到的關鍵數據出自v$filespace_usage視圖。
對v$filespace_usage圖,11g官方文檔的說明如下:
V$FILESPACE_USAGE summarizes space allocation information of each datafile and tempfile.
Column |
Datatype |
Description |
TABLESPACE_ID |
nubmer |
ID of the tablespace to which the file belongs |
RFNO |
NUMBER |
Relative file number of the file |
ALLOCATED_SPACE |
NUMBER |
Total allocated space in the file |
FILE_SIZE |
NUMBER |
Current file size |
FILE_MAXSIZE |
NUMBER |
Maximum file size |
CHANGESCN_BASE |
NUMBER |
SCN base of the last change to the file |
CHANGESCN_WRAP |
NUMBER |
SCN wrap of the last change to the file |
FLAG |
NUMBER |
Flags for file attributes |
根據以上分析,可以得出以下結論:
1、DBA_TABLESPACE_USED_SPACE是已經分配的空間,對應V$FILESPACE_USAGE的ALLOCATED_SPACE字段。
2、DBA_TABLESPACE_USAGE_METRICS的TABLESPACE_SIZE對應V$FILESPACE_USAGE的FILE_MAXSIZE字段(而不是FILE_SIZE)。注意:這裏對應的是最大值。如果數據文件是自動增長的,那麼,對於8k的block,這裏的最大值就是32G,也就是通過DBA_TABLESPACE_USAGE_METRICS視圖查詢顯示的4194302個blocks。
SQL> select * from dba_tablespace_usage_metrics;
TABLESPACE_NAME USED_SPACE TABLESPACE_SIZE USED_PERCENT
------------------------------ ---------- --------------- -------
SYSAUX 16576 4194302 .395202825
SYSTEM 33912 4194302 .808525471
TEMP 0 4194302 0
UNDOTBS1 288 4194302 .006866458
USERS 24 4194302 .000572205
而下面是用SQL腳本查詢到的表空間使用率情況,出入很大:
TABLESPACE_NAME SUM_SPACE SUM_BLOCKS USED_SPACE USED_RATE FREE_SPACE
---------- ---------- ---------- ---------- ---------- ----------
SYSAUX 140M 17920 129.56M 92.54% 10.44M
SYSTEM 300M 38400 265M 88.33% 35M
TEMP 20M 2560 16M 80% 4M
UNDOTBS1 200M 25600 19.31M 9.66% 180.69M
USERS 5M 640 .19M 3.8% 4.81M
下面測試對於自動擴展和非自動擴展的表空間,兩種方法的查詢結果:
1、創建表空間
TS1:自動擴展;
TS2:非自動擴展。
SQL> create tablespace TS1 datafile 'E:\oracle\product\10.2.0\oradata\ORCL\DATAFILE\ts01.dbf' size 100M autoextend on next 10M maxsize 1G;
表空間已創建。
SQL> create tablespace TS2 datafile 'E:\oracle\product\10.2.0\oradata\ORCL\DATAFILE\ts02.dbf' size 100M autoextend off;
表空間已創建。
2、分別使用兩種方法查看錶空間情況
(1)、使用DBA_TABLESPACE_USAGE_METRICS視圖
SQL> select * from dba_tablespace_usage_metrics where tablespace_name in ('TS1','TS2');
TABLESPACE_NAME USED_SPACE TABLESPACE_SIZE USED_PERCENT
------------------------------ ---------- --------------- -------
TS1 0 131072 0
TS2 0 12800 0
(2)、使用SQL腳本查看
TABLESPACE_NAME SUM_SPACE SUM_BLOCKS USED_SPACE USED_RATE FREE_SPACE
--------------- ---------- ---------- ---------- ----------
TS1 100M 12800 .06M .06% 99.94M
TS2 100M 12800 .06M .06% 99.94M
3、分別在兩個表空間創建一樣的表,插入數據
SQL> create table tt1 tablespace ts1 as select * from dba_objects;
表已創建。
SQL> insert into tt1 select * from dba_objects;
已創建11334行。
SQL> insert into tt1 select * from dba_objects;
已創建11334行。
SQL> insert into tt1 select * from dba_objects;
已創建11334行。
SQL> insert into tt1 select * from dba_objects;
已創建11334行。
SQL> insert into tt1 select * from dba_objects;
已創建11334行。
SQL> commit;
提交完成。
SQL> create table tt2 tablespace ts2 as select * from dba_objects;
表已創建。
SQL> insert into tt2 select * from dba_objects;
已創建11335行。
SQL> insert into tt2 select * from dba_objects;
已創建11335行。
SQL> insert into tt2 select * from dba_objects;
已創建11335行。
SQL> insert into tt2 select * from dba_objects;
已創建11335行。
SQL> insert into tt2 select * from dba_objects;
已創建11335行。
SQL> commit;
提交完成。
4、再用兩種方法查看錶空間使用情況
SQL> select * from dba_tablespace_usage_metrics where tablespace_name in ('TS1','TS2');
TABLESPACE_NAME USED_SPACE TABLESPACE_SIZE USED_PERCENT
--------------- ---------- --------------- ------------
TS1 896 131072 .68359375
TS2 896 12800 7
通過對比,表空間TS1和TS2實際使用的空間是一致的,都是896個block。但對於可以擴展的表空間TS1,這裏表空間的最大值爲131072個block,即指定的可以擴展到的1G。由此,計算出的使用率也就出現了偏差。因此,對於自動擴展的表空間,DBA_TABLESPACE_USAGE_METRICS視圖就不那麼適用了。
使用腳本:
TABLESPACE_NAME SUM_SPACE SUM_BLOCKS USED_SPACE USED_RATE FREE_SPACE
--------------- ---------- ---------- ---------- ----------
TS1 100M 12800 7.06M 7.06% 92.94M
TS2 100M 12800 7.06M 7.06% 92.94M
可以看出,通過腳本查詢出的結果,兩個表空間的使用率是一致的。
總結:
對於非自動擴展的表空間,使用DBA_TABLESPACE_USAGE_METRICS視圖,與傳統腳本使用的DBA_DATA_FILE和DBA_FREE_SPACE查詢的結果是一致的。
對於自動擴展的表空間,DBA_TABLESPACE_USAGE_METRICS視圖查詢的結果就不準確了,還要使用傳統的方法查詢。
轉自:http://blog.itpub.net/25744374/viewspace-774253