Oracle一個大事務的SQL往往不知道運行到了哪里,可以使用如下SQL查看執行進度。
復制代碼 代碼如下:
set linesize 400;
set pagesize 400;
col sql_text format a100;
col opname format a15;
SELECT se.sid,
opname,
TRUNC (sofar / totalwork * 100, 2) pct_work,
elapsed_seconds elapsed,
ROUND (elapsed_seconds * (totalwork - sofar) / sofar) remain_time,
sql_text
FROM v$session_longops sl, v$sqlarea sa, v$session se
WHERE sl.sql_hash_value = sa.hash_value
AND sl.sid = se.sid
AND sofar != totalwork
ORDER BY start_time;
或者
復制代碼 代碼如下:
set linesize 400;
set pagesize 400;
set long 4000;
col sql_fulltext format a100;
col opname format a15;
SELECT se.sid,
opname,
TRUNC (sofar / totalwork * 100, 2) pct_work,
elapsed_seconds elapsed,
ROUND (elapsed_seconds * (totalwork - sofar) / sofar) remain_time,
sql_fulltext
FROM v$session_longops sl, v$sqlarea sa, v$session se
WHERE sl.sql_hash_value = sa.hash_value
AND sl.sid = se.sid
AND sofar != totalwork
ORDER BY start_time;
您可能感興趣的文章:- Oracle數據庫中基本的查詢優化與子查詢優化講解
- 一些Oracle數據庫中的查詢優化建議綜合
- oracle跨庫查詢dblink的用法實例詳解
- Oracle數據庫中ORDER BY排序和查詢按IN條件的順序輸出
- Oracle 跨庫 查詢 復制表數據 分布式查詢介紹
- Oracle實現分頁查詢的SQL語法匯總
- ORACLE學習筆記-查詢篇
- 整理Oracle數據庫中數據查詢優化的一些關鍵點