SQL Server 查看死結的預存程序(轉載)

來源:互聯網
上載者:User

標籤:

if exists (select * from dbo.sysobjects where id = object_id(N‘[dbo].[sp_who_lock]‘) and OBJECTPROPERTY(id, N‘IsProcedure‘) = 1)drop procedure [dbo].[sp_who_lock]GOuse mastergocreate procedure sp_who_lockasbegindeclare @spid int,@bl int,        @intTransactionCountOnEntry int,        @intRowcount int,        @intCountProperties int,        @intCounter int        create table #tmp_lock_who (         id int identity(1,1),         spid smallint,         bl smallint)        IF @@ERROR<>0 RETURN @@ERROR        insert into #tmp_lock_who(spid,bl) 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        IF @@ERROR<>0 RETURN @@ERROR -- 找到暫存資料表的記錄數        select @intCountProperties = Count(*),@intCounter = 1        from #tmp_lock_who        IF @@ERROR<>0 RETURN @@ERROR         if @intCountProperties=0            select ‘現在沒有阻塞和死結資訊‘ as message-- 迴圈開始while @intCounter <= @intCountPropertiesbegin-- 取第一條記錄        select @spid = spid,@bl = bl        from #tmp_lock_who where Id = @intCounter         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 )            end -- 迴圈指標下移        set @intCounter = @intCounter + 1enddrop table #tmp_lock_whoreturn 0end

 

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.