(轉):學習Oracle動態效能表-(5)-V$SESSTAT
類似於v$sysstat,該檢視儲存下列類別的統計:
l 事件發生次數的統計,如使用者提交數。
l 資料產生,存取或者操作的total列(如:redo size)
l 執行操作所花費的時間累積,例如session CPU佔用(如果TIMED_STATISTICS值為true)
注意:
如果初始引數STATISTICS_LEVEL被設定為TYPICAL或ALL,時間統計被自動收集如果STATISTICS_LEVEL被設定為BASIC,你必須設定TIMED_STATISTICS值為TRUE以開啟收集功能。
如果你已設定了DB_CACHE_ADVICE,TIMED_STATISTICS或TIMED_OS_STATISTICS,或在初始引數檔案或使用ALTER_SYSTEM或ALTER SESSION,那麼你所設定的值的值將覆蓋STATISTICS_LEVEL的值。
v$sysstat和v$sesstat差別如下:
n v$sesstat只儲存session資料,而v$sysstat則儲存所有sessions的累積值。
n v$sesstat只是暫存資料,session退出後資料即清空。v$sysstat則是累積的,只有當例項被shutdown才會清空。
n v$sesstat不包括統計項名稱,如果要獲得統計項名稱則必須與v$sysstat或v$statname連線查詢獲得。
v$sesstat可被用於找出如下型別session:
n 高資源佔用
n 高平均資源佔用比(登陸後資源使用率)
n 預設資源佔用比(兩快照之間)
在V$SESSTAT中使用統計
多數v$sesstat中的統計參考是v$sysstat描述的子集,包括session logical reads, CPU used by this session, db block changes, redo size, physical writes, parse count (hard), parse count (total), sorts (memory), and sorts (disk).
V$SESSTAT常用列說明
n SID:session唯一ID
n STATISTIC#:資源唯一ID
n VALUE:資源使用
示例1:下列找出當前session中最高的logical和Physical I/O比率.
下列語句顯示了所有連線到資料庫的session邏輯、物理讀比率(每秒)。logical和physical I/O比率是透過自登陸後的時間消耗計算得出。對於sessions連線到資料庫這種長週期操作而言也許不夠精確,不過做個示例卻足夠了。
先獲得session邏輯讀和物理讀統計項的STATISTIC#值:
SELECTname, statistic#
FROMV$STATNAME
WHEREnameIN('session logical reads','physical reads') ;
NAME STATISTIC#
------------------------------ ----------
session logical reads 9
physical reads 40
透過上面獲得的STATISTIC#值執行下列語句:
SELECT ses.sid
, DECODE(ses.action,NULL,'online','batch') "User"
, MAX(DECODE(sta.statistic#,9,sta.value,0))
/greatest(3600*24*(sysdate-ses.logon_time),1) "Log IO/s"
, MAX(DECODE(sta.statistic#,40,sta.value,0))
/greatest(3600*24*(sysdate-ses.logon_time),1) "Phy IO/s"
, 60*24*(sysdate-ses.logon_time) "Minutes"
FROM V$SESSION ses
, V$SESSTAT sta
WHERE ses.status = 'ACTIVE'
AND sta.sid = ses.sid
AND sta.statistic# IN (9,40)
GROUP BY ses.sid, ses.action, ses.logon_time
ORDER BY
SUM( DECODE(sta.statistic#,40,100*sta.value,sta.value) )
/ greatest(3600*24*(sysdate-ses.logon_time),1) DESC;
SID User Log IO/s Phy IO/s Minutes
----- ------ -------- -------- -------
1951 batch 291 257.3 1
470 online 6,161 62.9 0
730 batch 7,568 43.2 197
2153 online 1,482 98.9 10
2386 batch 7,620 35.6 35
1815 batch 7,503 35.5 26
1965 online 4,879 42.9 19
1668 online 4,318 44.5 1
1142 online 955 69.2 35
1855 batch 573 70.5 8
1971 online 1,138 56.6 1
1323 online 3,263 32.4 5
1479 batch 2,857 35.1 3
421 online 1,322 46.8 15
2405 online 258 50.4 8
示例2:又例如透過v$sesstat和v$statname連線查詢某個SID各項資訊。
selecta.*,b.name
fromv$sesstat a,v$statname b
wherea.sid=10anda.statistic#=b.statistic#;
(2)-v$mystat
本檢視是v$sesstat的一個子集,返回當前session的統計項。當透過觸發器審計session資源使用,可以使用v$mystat來捕獲資源使用,這將比直接掃描v$sesstat的列要節省資源的多。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/9399028/viewspace-678253/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 學習動態效能表(二)--v$sesstat
- (轉):學習Oracle動態效能表-(12)-V$PROCESSOracle
- (轉):學習Oracle動態效能表-(10)-V$FILESTATOracle
- (轉):學習Oracle動態效能表-(8)-V$SESSIONOracleSession
- (轉)學習Oracle動態效能表-(4)-V$SYSSTATOracle
- (轉):學習Oracle動態效能表-(2)-V$SQLTEXTOracleSQL
- (轉):學習Oracle動態效能表-(1)-V$SQLAREAOracleSQL
- (轉):學習Oracle動態效能表-(21)-V$UNDOSTATOracle
- (轉):學習Oracle動態效能表-(19)-v$rowcacheOracle
- (轉):學習Oracle動態效能表-(18)-V$ROLLSTATOracle
- (轉):學習Oracle動態效能表-(7)-V$SQLTEXT,V$SQLAREAOracleSQL
- [轉]學習Oracle動態效能表-(6)-V$SQLTEXT,V$SQLAREAOracleSQL
- Oracle動態效能檢視學習筆記(2)_v$sesstat_v$mystat_v$statnameOracle筆記
- 學習oracle動態效能表--v$transactionOracle
- (轉):學習Oracle動態效能表-(22)-V$WAITSTATOracleAI
- (轉):學習Oracle動態效能表-(20)-V$SYSTEM_EVENTOracle
- (轉):學習Oracle動態效能表-(16)-V$OPEN_CURSOROracle
- (轉):學習Oracle動態效能表-(14)-V$SEGSTAT ,V$SEGMENT_STATISTICSOracle
- (轉):學習Oracle動態效能表-(11)-v$latch$ v$latch_childrenOracle
- (轉):學習Oracle動態效能表-(6)-V$SQL,V$SQL_PLANOracleSQL
- (轉)學習Oracle動態效能表-(3)V$LOCK,V$LOCKED_OBJECTOracleObject
- (轉):學習Oracle動態效能表-(17)-v$parameter & v$system_parameterOracle
- (轉):學習Oracle動態效能表-(13)-V$SESSION_LONGOPSOracleSessionGo
- (轉):學習Oracle動態效能表-(15)-V$DB_OBJECT_CACHEOracleObject
- (轉):學習Oracle動態效能表-(9)-V$SESSION_WAIT,V$SESSION_EVENTOracleSessionAI
- 學習動態效能表(19)--V$UNDOSTAT
- 學習動態效能表(16)--V$ROWCACHE
- 學習動態效能表(15)--V$ROLLSTAT
- 學習動態效能表(九)--V$FILESTAT
- 學習動態效能表(七)--V$PROCESS
- 學習動態效能表(一)--v$sysstat
- 學習動態效能表(五)-v$sessionSession
- 學習動態效能表(五)--V$SESSIONSession
- (轉)Oracle動態效能檢視學習之v$processOracle
- Oracle動態效能檢視學習之 V$ROLLSTAT -- 轉Oracle
- 學習動態效能表(20)--V$WAITSTATAI
- 學習動態效能表(八)-(1)-v$lock
- 學習動態效能表(三)-(1)-v$sqlSQL