微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何为我的SP查找阻止会话ID

如何解决如何为我的SP查找阻止会话ID

我有一个SP在夜间运行,有时无法完成。我自动运行的工具具有一个选项,该选项可以在一段时间后如果未完成就终止工作,即它可以终止工作,例如一小时后。

无论如何,我认为有时无法在最大分配时间内完成的原因是因为它被另一个会话ID阻止。如何查询DMV的查询文本,并准确查明阻止会话中的内容

我有查询,并且知道阻止的会话ID和会话ID。

SELECT TOP 100 w.session_id,w.wait_duration_ms,w.blocking_session_id,w.wait_type,e.database_id,D.name
FROM sys.dm_os_waiting_tasks w
LEFT JOIN sys.dm_exec_sessions e ON w.session_id = e.session_id
LEFT JOIN sys.databases d ON e.database_id = d.database_id
where w.session_id = x and w.blocking_session_id = y
order by w.wait_duration_ms desc

如何获取阻止会话ID的内容(例如SP的名称)?

解决方法

您可以下载并创建sp_whoisactive例程。它将为您提供当前发生情况的清晰详细信息。

例如,创建一个表:

DROP TABLE IF EXISTS dbo.TEST;

CREATE TABLE dbo.TEST
(
    [Column] INT 
);

在一个会话中,执行以下代码:

BEGIN TRAN;

INSERT INTO dbo.TEST
SELECT 1

-- commit tran

然后秒:

SELECT *
FROM dbo.TEST;

在第三步中,执行例程:

EXEC sp_Whoisactive

它将为您提供如下信息:

enter image description here

您可以清楚地看到SELECT被打开交易的会话阻止。

当例程在特定时刻返回活动时,您可能希望将详细信息记录在表中,并在以后进行分析。

如果您怀疑进程被阻塞或死锁受害者,那么创建仅收集这些事件的扩展事件会话将更为合适。有许多示例说明了如何完成此操作,它是easy。很好,因为您可以分析deadlock graph并更轻松地解决问题。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。