Oracle中查看慢查询进度的脚本分享

前端之家收集整理的这篇文章主要介绍了Oracle中查看慢查询进度的脚本分享前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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,
sql_fulltext
FROM v$session_longops sl,v$session se
WHERE sl.sql_hash_value = sa.hash_value
AND sl.sid = se.sid
AND sofar != totalwork
ORDER BY start_time;

原文链接:https://www.f2er.com/oracle/65225.html

猜你在找的Oracle相关文章