Sql Server 檢測死鎖的SQL語句


首先創建一個標量值函數DigLock,用來遞歸檢測SqlServer中的每一個會話是否存在加鎖循環,如果該函數最終返回1則表示檢測到了加鎖循環 (也就是說檢測到了死鎖),如果最終返回0則表示沒有檢測到加鎖循環。

 1 CREATE FUNCTION [dbo].[DigLock]
 2 (
 3     @spid int,
 4     @orginSpid int
 5 )
 6 RETURNS bit
 7 AS
 8 BEGIN
 9     declare @blockedSpid int=null;
10 
11     select @blockedSpid=spid from sysprocesses where blocked<>0 and blocked=@spid
12 
13     if @blockedSpid=@orginSpid
14         return 1;--檢測到了死鎖
15 
16     if @blockedSpid is not null
17     begin
18         return dbo.DigLock(@blockedSpid,@orginSpid);
19     end
20 
21     return 0;--未檢測到死鎖
22 END

 

然后定義一個視圖V_DeadLock_Process,調用上面創建的函數,如果查詢出了結果說明當前Sql Server中存在死鎖

1 CREATE VIEW [dbo].[V_DeadLock_Process]
2 AS
3 SELECT  spid, kpid, blocked, waittype, waittime, lastwaittype, waitresource, dbid, uid, cpu, physical_io, memusage, login_time, 
4                    last_batch, ecid, open_tran, status, sid, hostname, program_name, hostprocess, cmd, nt_domain, nt_username, 
5                    net_address, net_library, loginame, context_info, sql_handle, stmt_start, stmt_end, request_id
6 FROM      sys.sysprocesses AS sp1
7 WHERE   (blocked <> 0) AND (dbo.DigLock(spid, spid) = 1)

 

查詢視圖V_DeadLock_Process,如果當前Sql Server中存在死鎖的話就會顯示查詢到了記錄

Select * from [dbo].[V_DeadLock_Process]

上圖顯示,53號會話鎖住了54號會話,54號會話又鎖住了53號會話,所以當前Sql Server中存在死鎖。

 

然后可以使用DBCC INPUTBUFFER語句傳入上面視圖查詢到的會話spid,找到造成死鎖的Sql語句

DBCC INPUTBUFFER (53)--輸入會話spid,可查詢該會話正在執行的Sql語句,從而知道發生死鎖的會話執行了什么Sql語句

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM