學習動態效能表(十)--V$SESSION_LONGOPS
學習動態效能表第十篇--V$SESSION_LONGOPS
本檢視顯示執行超過6秒的操作的狀態。包括備份,恢復,統計資訊收集,查詢等等。
要監控查詢執行進展狀況,你必須使用cost-based最佳化方式,並且:
設定TIMED_STATISTICS或SQL_TRACE引數值為true。
透過ANALYZE或DBMS_STATS資料包收集物件統計資訊。
你可以透過DBMS_APPLICATION_INFO.SET_SESSION_LONGOPS過程新增application-specific長執行操作資訊到本檢視。關於DBMS_APPLICATION_INFO.SET_SESSION_LONGOPS的更多資訊可以瀏覽:Oracle Supplied PL/SQL Packages and Types Reference。
V$SESSION_LONGOPS列說明
SID:Session標識
SERIAL#:Session串號
OPNAME:操作簡要說明
TARGET:操作執行所在的物件
TARGET_DESC:目標物件說明
SOFAR:至今為止完成的工作量
TOTALWORK:總工作量
UNITS:工作量單位
START_TIME:操作開始時間
LAST_UPDATE_TIME:統計項最後更新時間
TIME_REMAINING:預計完成操作的剩餘時間(秒)
ELAPSED_SECONDS:從操作開始總花費時間(秒)
CONTEXT:前後關係
MESSAGE:統計項的完整描述
USERNAME:執行操作的使用者ID
SQL_ADDRESS:用於連線查詢的列
SQL_HASH_VALUE:用於連線查詢的列
QCSID:
示例:
找一較大表,確認該表查詢將超過6秒,哎呀讓它快我們沒把握,讓它慢這可是我的強項啊~~
SQL> set timing on
SQL> create table ttt as select level lv,rownum rn from dual connect by level<10000000; --建立一個臨時表
Table created
Executed in 19.5 seconds
SQL> commit;
Commit complete
Executed in 0 seconds
SQL> select * from (select * from ttt order by lv desc) where rownum<2; --執行一個費時的查詢
LV RN
---------- ----------
9999999 9999999
Executed in 9.766 seconds --哈哈,成功超過6秒
SQL> select sid,opname,sofar,totalwork,units,sql_hash_value from v$session_longops; ----看看v$session_longops中是不是已經有記錄了
SID OPNAME SOFAR TOTALWORK UNITS SQL_HASH_VALUE
---------- ---------------------------------------------------------------- ---------- ---------- -------------------------------- --------------
10 Table Scan 47276 47276 Blocks 2583310173
Executed in 0.047 seconds
SQL> select a.sql_text from v$sqlarea a,v$session_longops b where a.HASH_VALUE=b.SQL_HASH_VALUE; --透過hash_value聯絡查詢出剛執行的查詢語句。
SQL_TEXT
--------------------------------------------------------------------------------
select * from (select * from ttt order by lv desc) where rownum<2
Executed in 0.063 seconds
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/751371/viewspace-561513/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- (轉):學習Oracle動態效能表-(13)-V$SESSION_LONGOPSOracleSessionGo
- 動態檢視V$SESSION_LONGOPS學習SessionGo
- 學習oracle動態效能表--v$transactionOracle
- 學習動態效能表(19)--V$UNDOSTAT
- 學習動態效能表(16)--V$ROWCACHE
- 學習動態效能表(15)--V$ROLLSTAT
- 學習動態效能表(九)--V$FILESTAT
- 學習動態效能表(七)--V$PROCESS
- 學習動態效能表(二)--v$sesstat
- 學習動態效能表(一)--v$sysstat
- 學習動態效能表(五)-v$sessionSession
- 學習動態效能表(五)--V$SESSIONSession
- 學習動態效能表(20)--V$WAITSTATAI
- 學習動態效能表(八)-(1)-v$lock
- 學習動態效能表(三)-(1)-v$sqlSQL
- 學習動態效能表(四)-(2)-V$SQLAREASQL
- 學習動態效能表(四)-(1)-v$sqltextSQL
- 學習動態效能表(八)-(2)-v$lock
- 學習動態效能表(18)--V$SYSTEM_EVENT
- (轉):學習Oracle動態效能表-(12)-V$PROCESSOracle
- (轉):學習Oracle動態效能表-(10)-V$FILESTATOracle
- (轉):學習Oracle動態效能表-(8)-V$SESSIONOracleSession
- (轉):學習Oracle動態效能表-(5)-V$SESSTATOracle
- (轉)學習Oracle動態效能表-(4)-V$SYSSTATOracle
- (轉):學習Oracle動態效能表-(2)-V$SQLTEXTOracleSQL
- (轉):學習Oracle動態效能表-(1)-V$SQLAREAOracleSQL
- (轉):學習Oracle動態效能表-(21)-V$UNDOSTATOracle
- (轉):學習Oracle動態效能表-(19)-v$rowcacheOracle
- (轉):學習Oracle動態效能表-(18)-V$ROLLSTATOracle
- 學習動態效能表(13)--V$OPEN_CURSOR
- 學習動態效能表(11)--v$latch$v$latch_children
- (轉):學習Oracle動態效能表-(7)-V$SQLTEXT,V$SQLAREAOracleSQL
- [轉]學習Oracle動態效能表-(6)-V$SQLTEXT,V$SQLAREAOracleSQL
- 學習動態效能表
- 學習動態效能表(17)--v$segstat&v$segment_statistics
- 學習動態效能表(14)--V$PARAMETER&V$SYSTEM_PARAMETER
- 學習動態效能表(12)--V$DB_OBJECT_CACHEObject
- 學習動態效能表(八)-(3)-V$LOCKED_OBJECTObject