SQL Server 数据库中关于死锁的分析

熊孩子他大舅

熊孩子他大舅

2016-01-29 16:06

SQL Server 数据库中关于死锁的分析,SQL Server 数据库中关于死锁的分析

SQL Server数据库发生死锁时不会像ORACLE那样自动生成一个跟踪文件。有时可以在[管理]-[当前活动] 里看到阻塞信息(有时SQL Server企业管理器会因为锁太多而没有响应).

设定跟踪1204:

USE MASTER

DBCC TRACEON (1204,-1)

显示当前启用的所有跟踪标记的状态:

DBCC TRACESTATUS(-1)

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/sqlserver/)

取消跟踪1204:

DBCC TRACEOFF (1204,-1)

在设定跟踪1204后,会在数据库的日志文件里显示SQL Server数据库死锁时一些信息。但那些信息很难看懂,需要对照SQL Server联机丛书仔细来看。根据PAG锁要找到相关数据库表的方法:

DBCC TRACEON (3604)DBCC PAGE (db_id,file_id,page_no)DBCC TRACEOFF (3604)

请参考sqlservercentral.com上更详细的讲解.但又从CSDN学到了一个找到死锁原因的方法。我稍加修改, 去掉了游标操作并增加了一些提示信息,写了一个系统存储过程sp_who_lock.sql。代码如下:

if exists (select * from dbo.sysobjectswhere id = object_id(N'[dbo].[sp_who_lock]')and OBJECTPROPERTY(id, N'IsProcedure') = 1)drop procedure [dbo].[sp_who_lock]GO/********************************************************//  创建 : fengyu  邮件 : maggiefengyu@tom.com//  日期 :2004-04-30//  修改 : 从http://www.csdn.net/develop/Read_Article.asp?id=26566//  学习到并改写//  说明 : 查看数据库里阻塞和死锁情况********************************************************/use mastergocreate procedure sp_who_lockasbegindeclare @spid int,@bl int,@intTransactionCountOnEntry     int,@intRowcount             int,@intCountProperties         int,@intCounter             intcreate table #tmp_lock_who (id int identity(1,1),spid smallint,bl smallint)IF @@ERROR<0 RETURN @@ERRORinsert into #tmp_lock_who(spid,bl) select  0 ,blockedfrom (select * from sysprocesses where  blocked0 ) awhere not exists(select * from (select * from sysprocesseswhere  blocked0 ) bwhere a.blocked=spid)union select spid,blocked from sysprocesses where  blocked0IF @@ERROR<0 RETURN @@ERROR-- 找到临时表的记录数select     @intCountProperties = Count(*),@intCounter = 1from #tmp_lock_whoIF @@ERROR<0 RETURN @@ERRORif    @intCountProperties=0select '现在没有阻塞和死锁信息' as message-- 循环开始while @intCounter <= @intCountPropertiesbegin-- 取第一条记录select     @spid = spid,@bl = blfrom #tmp_lock_who where Id = @intCounterbeginif @spid =0select '引起数据库死锁的是: '+ CAST(@bl AS VARCHAR(10))+ '进程号,其执行的SQL语法如下'elseselect '进程号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

需要的时候直接调用:

sp_who_lock

(本文来源于图老师网站,更多请访问https://m.tulaoshi.com/sqlserver/)

展开更多 50%)
分享

猜你喜欢

SQL Server 数据库中关于死锁的分析

SQLServer
SQL Server 数据库中关于死锁的分析

减少SQL Server数据库死锁的方法

编程语言 网络编程
减少SQL Server数据库死锁的方法

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

SQL Server死锁的分析

SQLServer
SQL Server死锁的分析

SQL Server数据库检修

SQLServer
SQL Server数据库检修

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

SQL Server数据库导入MySQL数据库体验

MySQL mysql数据库
SQL Server数据库导入MySQL数据库体验

关于SQL Server数据库的若干注意事项

SQLServer
关于SQL Server数据库的若干注意事项

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

SyGate代理上网故障两例

SyGate代理上网故障两例

将ACCESS转化成SQL2000需要注意的几个问题

将ACCESS转化成SQL2000需要注意的几个问题
下拉加载更多内容 ↓