標籤:死結 lock server cat 手工 資料庫 一個 進程id 修改
修改或刪除資料前先備份,先備份,先備份(重要事情說三遍)!
1、首先,查看線程,分析是否存在阻塞進程,blocked>0都是當前被阻塞的進程
SELECT * FROM sysprocesses where blocked >0 order by blocked ;
2、找到被阻塞的線程後,想要繼續查看進程被誰阻塞,分析導致阻塞的源頭
SELECT * FROM SYSPROCESSES WHERE spid =spid_no(這是你要分析的進程ID)
3、查看此進程執行的SQL 是哪個,尋找問題原因
dbcc inputbuffer(spid);
4、如果想要結束當前進程,KILL 掉當前置致阻塞的SQL
kill spid
以上是手工分析,當前生產有哪些阻塞並自動分析出來源頭,我下面提供一個自己整理的自動分析過程,親測有效,可直接使用:
use master
go
declare @spid int,@bl int
DECLARE s_cur CURSOR FOR
select 0 ,blocked
from (select * from sysprocesses where blocked>0 ) a
where not exists(select * from (select * from sysprocesses where blocked>0 ) b
where a.blocked=spid)
union select spid,blocked from sysprocesses where blocked>0
OPEN s_cur
FETCH NEXT FROM s_cur INTO @spid,@bl
WHILE @@FETCH_STATUS = 0
begin
if @spid =0
select ‘引起資料庫死結的是:
‘+ CAST(@bl AS VARCHAR(10)) + ‘進程號,其執行的SQL文法如下‘
else
select ‘進程號SPID:‘+ CAST(@spid AS VARCHAR(10))+ ‘被‘ + ‘
進程號SPID:‘+ CAST(@bl AS VARCHAR(10)) +‘阻塞,其當前進程執行的SQL文法如下‘
DBCC INPUTBUFFER (@bl )
FETCH NEXT FROM s_cur INTO @spid,@bl
end
CLOSE s_cur
DEALLOCATE s_cur
SQL Server 查看進程阻塞及處理