SQL Server 查看進程阻塞及處理

來源:互聯網
上載者:User

標籤:死結   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 查看進程阻塞及處理

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.