(轉):學習Oracle動態效能表-(13)-V$SESSION_LONGOPS
V$SESSION_LONGOPS
本檢視顯示執行超過6秒的操作的狀態。包括備份,恢復,統計資訊收集,查詢等等。
要監控查詢執行進展狀況,你必須使用cost-based最佳化方式,並且:
l 設定TIMED_STATISTICS或SQL_TRACE引數值為true。
l 透過ANALYZE或DBMS_STATS資料包收集物件統計資訊。
你可以透過DBMS_APPLICATION_INFO.SET_SESSION_LONGOPS過程新增application-specific長執行操作資訊到本檢視。關於DBMS_APPLICATION_INFO.SET_SESSION_LONGOPS的更多資訊可以瀏覽: Supplied PL/SQL Packages and Types Reference。
V$SESSION_LONGOPS列說明
l SID:Session標識
l SERIAL#:Session串號
l OPNAME:操作簡要說明
l TARGET:操作執行所在的物件
l TARGET_DESC:目標物件說明
l SOFAR:至今為止完成的量
l TOTALWORK:總工作量
l UNITS:工作量單位
l START_TIME:操作開始時間
l LAST_UPDATE_TIME:統計項最後更新時間
l TIME_REMAINING:預計完成操作的剩餘時間(秒)
l ELAPSED_SECONDS:從操作開始總花費時間(秒)
l CONTEXT:前後關係
l MESSAGE:統計項的完整描述
l USERNAME:執行操作的使用者ID
l SQL_ADDRESS:用於連線查詢的列
l SQL_HASH_VALUE:用於連線查詢的列
l 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
Ps:itpub論壇的fenng版版數年前有篇描述了v$sessin_longops的來源,有興趣的朋友可以研究研究:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/9399028/viewspace-678262/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 利用v$session_longops監控長操作SessionGo
- Flutter學習筆記(13)--表單元件Flutter筆記元件
- Oracle's V$ Views(轉)OracleView
- 動態生成表-判斷表是否存在效能對比
- Oracle 巢狀表(轉)Oracle巢狀
- oracle大表效能最佳化Oracle
- 3/13學習程序
- 6/13學習程序
- 動態規劃學習筆記動態規劃筆記
- oracle 表移動表空間Oracle
- Oracle表移動表空間Oracle
- JavaScript學習筆記13JavaScript筆記
- Arduino學習筆記13UI筆記
- Oracle Haip無法啟動問題學習OracleAI
- 機器學習的靜態特徵和動態特徵機器學習特徵
- 跟我一起學習和開發動態表單系統-動態表單系統的技術實現與優勢(2)
- Oracle Tuning (Oracle 效能調整)的一些總結(轉)Oracle
- 【MyBatis學習總結 (五),動態SQL】MyBatisSQL
- 動態元件與v-on元件
- 【學習圖片】13.自動壓縮和編碼
- mORMot 1.18 第13章 動態陣列ORM陣列
- 【react】實現動態表單中巢狀動態表單React巢狀
- 李沐動手學深度學習V2-chap_preliminaries深度學習
- Vue.js基礎學習(三) -------------動態繫結v-bind的介紹和使用Vue.js
- Oracle Tuning (Oracle 效能調整)的一些總結(轉)2Oracle
- Oracle DG資料庫狀態轉換Oracle資料庫
- 13、資料,學習和建模
- ABAP動態內表
- angular動態表單Angular
- 動手學強化學習(四):動態規劃演算法強化學習動態規劃演算法
- Python學習筆記6——動態型別Python筆記型別
- java反射之動態代理學習筆記Java反射筆記
- DEDE整站動態/靜態轉換
- 強化學習-學習筆記13 | 多智慧體強化學習強化學習筆記智慧體
- Oracle學習路線Oracle
- Oracle學習總結Oracle
- oracle之 手動建立 emp 表 與 dept 表Oracle
- oracle的靜態註冊和動態註冊Oracle
- Python學習之路13-記分Python