查询长事务和SQL执行等待间隔时间

本文介绍如何使用SQLProfile工具跟踪并分析SQL事务,通过查询获取事务的SQL数量及执行时间,进一步了解SQL执行的等待间隔时间。

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

   通过SQL Profile跟踪SQL,并将跟踪的sql存入表中,运行下列语句就可以获取长事务的id,在EXCEL中通过TransactionID 筛选就可以得到事务的sql和运行时间。

   

select  TransactionID [事务编号],
        
count(*[SQL条数],
        
datediff(second, min(StartTime), max(EndTime)) [事务时间S]
from    yy
where TransactionID is not null
group by TransactionID
order by 3 

 

   SQL执行等待间隔时间
 
 SELECT t.TransactionID 事务ID,DATEDIFF(s,t.EndTime,t2.StartTime) [事务SQL间隔时间S],
 t.StartTime,t.EndTime FROM
 (SELECT TransactionID, DENSE_RANK() OVER (partition BY  TransactionID ORDER BY eventsequence) rn,
 StartTime,EndTime,TextData
 FROM yy 
 WHERE TransactionID IS NOT NULL) t ,
 (SELECT TransactionID, DENSE_RANK() OVER (partition BY  TransactionID ORDER BY eventsequence) rn,
 StartTime,EndTime,TextData
 FROM yy 
 WHERE TransactionID IS NOT NULL) t2 
 WHERE t.TransactionID
=t2.TransactionID AND t2.rn=t.rn+1
 ORDER BY 
2 desc

 

转载于:https://www.cnblogs.com/zping/archive/2011/03/31/2001105.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值