php查询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,

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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值