學習動態效能表(13)--V$OPEN_CURSOR

junsansi發表於2007-06-12

學習動態效能表(一)--v$sysstat
http://junsansi.itpub.net/post/29894/291051

學習動態效能表(二)--v$sesstat
http://junsansi.itpub.net/post/29894/291243

學習動態效能表(三)--v$sql&v$sql_plan
1.http://junsansi.itpub.net/post/29894/291651
2.http://junsansi.itpub.net/post/29894/291652

學習動態效能表(四)--v$sqltext&v$sqlarea
1.http://junsansi.itpub.net/post/29894/291654
2.http://junsansi.itpub.net/post/29894/291656

學習動態效能表(五)--v$session
http://junsansi.itpub.net/post/29894/292372

學習動態效能表(六)--v$session_wait&v$session_event
1.http://junsansi.itpub.net/post/29894/292373
2.http://junsansi.itpub.net/post/29894/292375

學習動態效能表(七)--v$process
http://junsansi.itpub.net/post/29894/292558

學習動態效能表(八)--v$lock&v$locked_object
1.http://junsansi.itpub.net/post/29894/292816
2.http://junsansi.itpub.net/post/29894/292819
3.http://junsansi.itpub.net/post/29894/292825

學習動態效能表(九)--V$FILESTAT
http://junsansi.itpub.net/post/29894/293209

學習動態效能表(十)--V$SESSION_LONGOPS
http://junsansi.itpub.net/post/29894/293212

學習動態效能表(11)--v$latch$v$latch_children
http://junsansi.itpub.net/post/29894/294342

學習動態效能表(12)--V$DB_OBJECT_CACHE
http://junsansi.itpub.net/post/29894/294343


學習動態效能表第13篇--V$OPEN_CURSOR

  本檢視列出session開啟的所有cursors,很多時候都將被用到,比如:你可以通過它檢視各個session開啟的cursor數。

  當診斷系統資源佔用時,它常被用於聯接v$sqlarea和v$sql查詢出特定SQL(高邏輯或物理I/O)。然後,下一步就是找出源頭。在應用環境,基本都是同一類使用者登陸到資料庫(在V$SQLAREA中擁有相同的PARSING_USER_ID),而通過這個就可以找出它們的不同。V$SQLAREA中的統計項在語句完全執行後被更新(並且從V$SESSION.SQL_HASH_VALUE中消失)。因此,你不能直接找到session除非語句被再次執行。不過如果session的cursor仍然開啟著,你可以通過v$open_cursor找出執行這個語句的session。

V$OPEN_CURSOR中的連線列

Column View Joined Column(s)
----------------------------- ---------------------------------------- -----------------------------
HASH_VALUE, ADDRESS V$SQLAREA, V$SQL, V$SQLTEXT HASH_VALUE, ADDRESS
SID V$SESSION SID

示例:
1.找出執行某語句的session:
SELECT hash_value, buffer_gets, disk_reads
FROM V$SQLAREA
WHERE disk_reads > 1000000
ORDER BY buffer_gets DESC;

HASH_VALUE BUFFER_GETS DISK_READS
---------- ----------- ----------
1514306888 177649108 3897402
478652562 63168944 2532721
360282550 14158750 2482065

3 rows selected.
SQL> SELECT sid FROM V$SESSION WHERE sql_hash_value = 1514306888 ;
no rows selected
--直接通過hash_value查詢v$session,沒有記錄

SQL> SELECT sid FROM V$OPEN_CURSOR WHERE hash_Value = 1514306888 ;

SID
-----
1125
233
935
1693
531

5 rows selected.
--通過hash_value在v$open_cursor中查詢sid(只有在session的cursor仍然開啟的情況下才有可能找到)

2.列出擁有超過400個cursor的sessionID
SQL> SELECT sid, count(0) ct FROM v$open_cursor
GROUP BY sid HAVING COUNT(0) > 400 ORDER BY ct desc;

事實上,v$open_cursor是一個相當常用的檢視,特別是web開發應用的時候。僅通過它一個檢視你就能分析出當前的連線情況,主要執行語句等。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7607759/viewspace-22242/,如需轉載,請註明出處,否則將追究法律責任。

相關文章