查询长事务SQL

此SQL查询用于找出数据库中执行超过特定时间(如100秒)的事务信息,包括事务开始时间、会话ID、SQL_ID、等待类型等详细数据。通过结合v$transaction、v$session和v$transaction_enqueue视图,可以有效识别并定位长事务问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下面SQL 查询数据库中正在执行大于N秒的事务信息:

with ltr as (
select to_char(sysdate,'YYYYMMDDHH24MISS') TM,
       s.sid,
       s.sql_id,
       s.sql_child_number,
       s.prev_sql_id,
       xid,
       to_char(t.start_date,'YYYYMMDDHH24MISS') start_time,
       e.TYPE,e.block,
       e.ctime,
       decode(e.CTIME, 0, (sysdate - t.start_date) * 3600*24, e.ctime) el_second  
     --  q.sql_text
  from v$transaction t, v$session s,v$transaction_enqueue e
 where t.start_date <= sysdate - interval '100' second     /*查询开始多少秒的事务*/
   and t.addr = s.taddr
   --and s.sql_child_number = q.CHILD_NUMBER(+)
   --and s.sql_id = q.sql_id(+) and s.prev_sql_id = q.sql_id(+)
   and t.addr = e.addr(+) )  
  select ltr.* , (select q1.sql_text from v$sql q1 where ltr.prev_sql_id = q1.sql_id(+)
   and rownum = 1) prev_sql_text ,
  (select q1.sql_text from v$sql q1 where ltr.sql_id = q1.sql_id(+)
   and ltr.sql_child_number = q1.CHILD_NUMBER(+)) sql_text
   from ltr ltr;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值