sql server deadlock跟蹤的4種實(shí)現(xiàn)方法
前言
最近寫(xiě)程序常會(huì)遇到deadlock victim,每次一臉懵逼。研究了下怎么跟蹤,寫(xiě)下來(lái)記錄下。文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧
建測(cè)試數(shù)據(jù)
CREATE DATABASE testdb;
GO
USE testdb;
CREATE TABLE table1
(
id INT IDENTITY PRIMARY KEY,
student_name NVARCHAR(50)
)
INSERT INTO table1 values ('James')
INSERT INTO table1 values ('Andy')
INSERT INTO table1 values ('Sal')
INSERT INTO table1 values ('Helen')
INSERT INTO table1 values ('Jo')
INSERT INTO table1 values ('Wik')
CREATE TABLE table2
(
id INT IDENTITY PRIMARY KEY,
student_name NVARCHAR(50)
)
INSERT INTO table2 values ('Alan')
INSERT INTO table2 values ('Rik')
INSERT INTO table2 values ('Jack')
INSERT INTO table2 values ('Mark')
INSERT INTO table2 values ('Josh')
INSERT INTO table2 values ('Fred')
第一段sql,先運(yùn)行只更新table1部分
USE testdb; -- Transaction1 BEGIN TRAN UPDATE table1 SET student_name = student_name + 'Transaction1' WHERE id IN (1,2,3,4,5) UPDATE table2 SET student_name = student_name + 'Transaction1' WHERE id = 1 COMMIT TRANSACTION
第二段sql,只運(yùn)行更新table2部分
USE testdb; -- Transaction2 BEGIN TRAN UPDATE table2 SET student_name = student_name + 'Transaction2' WHERE id = 1 UPDATE table1 SET student_name = student_name + 'Transaction2' WHERE id IN (1,2,3,4,5) COMMIT TRANSACTION
再運(yùn)行,第一段sql更新table2,運(yùn)行第二段sql更新table1,死鎖問(wèn)題重現(xiàn)。

說(shuō)下跟蹤死鎖的方法:
1.使用trace log跟蹤,執(zhí)行如下sql開(kāi)啟1222和1204 flag,死鎖信息會(huì)在sql server 日志中輸出。
DBCC TRACEON (1204, -1) DBCC TRACEON (1222, -1)
下圖是1204輸出的信息

下圖是1222輸出的信息

2.使用sql server profiler進(jìn)行跟蹤
點(diǎn)擊Tools -> sql server profiler 選擇sql locks模板

運(yùn)行當(dāng)發(fā)生死鎖時(shí)會(huì)自動(dòng)捕獲,點(diǎn)擊dead lock paragraph查看死鎖

3.使用擴(kuò)展事件跟蹤,方法只適用于sql server 2012版本,08r2版本無(wú)法直接使用。
依次點(diǎn)擊Management -> Extended Events - >system health - >package0.event_file

輸入deadlock回車(chē),可以點(diǎn)擊details 把內(nèi)容另存為xdl文件再打開(kāi),或點(diǎn)擊deadlock查看圖

4.使用windows性能計(jì)數(shù)器檢測(cè)到死鎖再去sql中查詢
命令行輸入:perfmon 或者 perfmon /sys
選擇實(shí)例:SQL Server :Locks \\ Number of DeadLocks/sec \\ _Total
實(shí)時(shí)查看:

下面的查詢提供了自從上次重啟以來(lái)在本服務(wù)器上發(fā)生的所有死鎖:
SELECT cntr_value AS NumOfDeadLocks
FROM sys.dm_os_performance_counters
WHERE object_name = 'SQLServer:Locks'
AND counter_name = 'Number of Deadlocks/sec'
AND instance_name = '_Total'
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
SQLSERVER對(duì)索引的利用及非SARG運(yùn)算符認(rèn)識(shí)
SQL對(duì)篩選條件簡(jiǎn)稱:SARG(search argument/SARG)當(dāng)然這里不是說(shuō)SQLSERVER的where子句,是說(shuō)SQLSERVER對(duì)索引的利用,感興趣的朋友可以了解下,或許本文的知識(shí)點(diǎn)對(duì)你有所幫助哈2013-02-02
SQL語(yǔ)句練習(xí)實(shí)例之四 找出促銷活動(dòng)中銷售額最高的職員
你剛在一家服裝銷售公司中找到了一份工作,此時(shí)經(jīng)理要求你根據(jù)數(shù)據(jù)庫(kù)中的兩張表得到促銷活動(dòng)銷售額最高的銷售員2011-10-10
SQL?Server日志清理3種實(shí)現(xiàn)方式
這篇文章主要給大家介紹了關(guān)于SQL?Server日志清理3種實(shí)現(xiàn)方式的相關(guān)資料,在數(shù)據(jù)庫(kù)使用很久后日志文件會(huì)累計(jì)的越來(lái)越大,如果硬盤(pán)空間不足可能會(huì)導(dǎo)致宕機(jī),需要的朋友可以參考下2023-09-09
SQL Server 總結(jié)復(fù)習(xí)(一)
寫(xiě)這篇文章,主要是總結(jié)最近學(xué)到的一些新知識(shí),這些特性不一定是SQLSERVER最新版才有,大多數(shù)是2008新特性,有些甚至是更早。如果有不懂的地方,建議大家去百度谷歌搜搜,本文不做詳細(xì)闡述,有錯(cuò)誤的地方,歡迎大家批評(píng)指正2012-08-08
自己收集比較強(qiáng)大的分頁(yè)存儲(chǔ)過(guò)程 推薦
這兩天幫朋友修改一個(gè)項(xiàng)目,看到一個(gè)存儲(chǔ)過(guò)程,感覺(jué)性能非常高。于是,整合自己以前搜集的比較好的存儲(chǔ)過(guò)程,拿來(lái)跟大家分享下2011-11-11
SQL Server中避免觸發(fā)鏡像SUSPEND的N種方法
這篇文章主要介紹了SQL Server中避免觸發(fā)鏡像SUSPEND的N種方法,需要的朋友可以參考下2016-01-01
SQL BETWEEN 的常見(jiàn)用法小結(jié)
BETWEEN操作符是SQL中非常有用的工具,它允許你快速選取某個(gè)范圍內(nèi)的值,本文給大家介紹SQL BETWEEN 的常見(jiàn)用法,感興趣的朋友一起看看吧2025-04-04
盤(pán)點(diǎn)SqlServer?分頁(yè)方式和拉姆達(dá)表達(dá)式分頁(yè)
這篇文章主要介紹了SqlServer?5種分頁(yè)方式和拉姆達(dá)表達(dá)式分頁(yè),進(jìn)來(lái)看看吧,本文結(jié)合示例代碼給大家講解的非常詳細(xì),需要的朋友可以參考下2022-12-12

