SQL超過鎖請求

2022-09-12 16:24:44 字數 3729 閱讀 8898

---超過鎖請求

1、查詢造成死鎖的sql語句

當sql資料庫的監控報警顯示死鎖程序數過多時,首先應該找出造成死鎖的sql語句是什麼,開啟「查詢分析器」,將如下的儲存過程輸入到文字框中,檢查語法,然後執行:

use master

gocreate procedure sp_who_lock as

begin

declare @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<=@intcountproperties

begin

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)

endset @intcounter=@intcounter+1

enddrop table #tmp_lock_who

return 0

end執行完畢,輸入exec sp_who_lock 執行儲存過程,這時候就可以明確的找出哪個sql語句造成的死鎖和阻塞。

2、殺死鎖和程序

我們找出了引起死鎖的語句,那麼如何去手動的殺死程序和鎖?最簡單的辦法,重新啟動服務。但是這裡要介紹乙個儲存過程,通過顯式的呼叫,可以殺死程序和鎖。

use master

goif exists (select * from dbo.sysobjects where id = object_id(n'[dbo].[p_killspid]') and objectproperty(id, n'isprocedure') = 1)

drop procedure [dbo].[p_killspid]

gocreate proc p_killspid

@dbname varchar(200) --要關閉程序的資料庫名

as

declare @sql nvarchar(500)

declare @spid nvarchar(20)

declare #tb cursor for

select spid=cast(spid as varchar(20)) from master..sysprocesses where dbid=db_id(@dbname)

open #tb

fetch next from #tb into @spid

while @@fetch_status=0

begin

exec('kill '+@spid)

fetch next from #tb into @spid

end

close #tb

deallocate #tb

go--用法

exec p_killspid 'newdbpy'

3、檢視鎖資訊

如何檢視系統中所有鎖的詳細資訊?在企業管理管理器中,我們可以看到一些程序和鎖的資訊,這裡介紹另外一種方法。

--檢視鎖資訊

create table #t(req_spid int,obj_name sysname)

declare @s nvarchar(4000)

,@rid int,@dbname sysname,@id int,@objname sysname

declare tb cursor for

select distinct req_spid,dbname=db_name(rsc_dbid),rsc_objid

from master..syslockinfo where rsc_type in(4,5)

open tb

fetch next from tb into @rid,@dbname,@id

while @@fetch_status=0

begin

set @s='select @objname=name from ['+@dbname+']..sysobjects where id=@id'

exec sp_executesql @s,n'@objname sysname out,@id int',@objname out,@id

insert into #t values(@rid,@objname)

fetch next from tb into @rid,@dbname,@id

endclose tb

deallocate tb

select 程序id=a.req_spid

,資料庫=db_name(rsc_dbid)

,型別=case rsc_type when 1 then 'null 資源(未使用)'

when 2 then '資料庫'

when 3 then '檔案'

when 4 then '索引'

when 5 then '表'

when 6 then '頁'

when 7 then '鍵'

when 8 then '擴充套件盤區'

when 9 then 'rid(行 id)'

when 10 then '應用程式'

end,物件id=rsc_objid

,物件名=b.obj_name

,rsc_indid

from master..syslockinfo a left join #t b on a.req_spid=b.req_spid

godrop table #t

Sql 報 「已超過了鎖請求超時時段」

問題 某日 的某個頁面突然卡死,debug提示已超過了鎖請求超時時段的原因 原因 應該是資料庫表體積很大,處理的時候費事,因為幾乎所有資料庫操作都需要加或多或少的鎖,所以會超時。或者是某乙個儲存過程未提交事務,導致超時。解決方案 首先可以使用 select from sys.sysprocesses...

已超過了鎖請求超時時段的原因

應該是你的表體積很大,處理的時候費事,因為幾乎所有資料庫操作都需要加或多或少的鎖,所以會超時。首先你可以使用select from sys.sysprocesses where blocked 0查查有哪些程序阻塞了。然後拿spid,執行dbcc inputbuffer spid 來檢查是什麼語句造...

錯誤 1222 已超過了鎖請求超時時段

問題原因 重新整理當前活動將呼叫 sp msset current activity 儲存過程。在定義該儲存過程時,首先將 lock timeout 變數設定為 5000 毫秒 ms 然後,會建立兩個全域性臨時表,它們針對下面的系統表在表級別發出 ix 鎖,在鍵級別發出 x 鎖 tempdb.sys...