Sql Server 检测死锁的SQL语句
2016-06-03 20:35
351 查看
首先创建一个标量值函数DigLock,用来递归检测SqlServer中的每一个会话是否存在加锁循环,如果该函数最终返回1则表示检测到了加锁循环 (也就是说检测到了死锁),如果最终返回0则表示没有检测到加锁循环。
然后定义一个视图V_DeadLock_Process,调用上面创建的函数,如果查询出了结果说明当前Sql Server中存在死锁
查询视图V_DeadLock_Process,如果当前Sql Server中存在死锁的话就会显示查询到了记录
上图显示,53号会话锁住了54号会话,54号会话又锁住了53号会话,所以当前Sql Server中存在死锁。
然后可以使用DBCC INPUTBUFFER语句传入上面视图查询到的会话spid,找到造成死锁的Sql语句
CREATE FUNCTION [dbo].[DigLock] ( @spid int, @orginSpid int ) RETURNS bit AS BEGIN declare @blockedSpid int=null; select @blockedSpid=spid from sysprocesses where blocked<>0 and blocked=@spid if @blockedSpid=@orginSpid return 1;--检测到了死锁 if @blockedSpid is not null begin return dbo.DigLock(@blockedSpid,@orginSpid); end return 0;--未检测到死锁 END
然后定义一个视图V_DeadLock_Process,调用上面创建的函数,如果查询出了结果说明当前Sql Server中存在死锁
CREATE VIEW [dbo].[V_DeadLock_Process] AS SELECT spid, kpid, blocked, waittype, waittime, lastwaittype, waitresource, dbid, uid, cpu, physical_io, memusage, login_time, last_batch, ecid, open_tran, status, sid, hostname, program_name, hostprocess, cmd, nt_domain, nt_username, net_address, net_library, loginame, context_info, sql_handle, stmt_start, stmt_end, request_id FROM sys.sysprocesses AS sp1 WHERE (blocked <> 0) AND (dbo.DigLock(spid, spid) = 1)
查询视图V_DeadLock_Process,如果当前Sql Server中存在死锁的话就会显示查询到了记录
Select * from [dbo].[V_DeadLock_Process]
上图显示,53号会话锁住了54号会话,54号会话又锁住了53号会话,所以当前Sql Server中存在死锁。
然后可以使用DBCC INPUTBUFFER语句传入上面视图查询到的会话spid,找到造成死锁的Sql语句
DBCC INPUTBUFFER (53)--输入会话spid,可查询该会话正在执行的Sql语句,从而知道发生死锁的会话执行了什么Sql语句
相关文章推荐
- JDBC以SQL Server身份验证方式连接SQL Server2014
- 2、.getcom.mchange.v2.c3p0.impl.NewProxyConnection cannot becast to com.mysql.jdbc.Connection
- mysql 入门基础(4)—约束和视图
- SQL 查找一个字段的首字母是以A~Z为首的数据
- ubuntu下安装redis拓展、windows下安装redis拓展
- redis服务启动和停止
- 对于数据库范式的一点理解
- redis.clients.jedis.exceptions.JedisDataException: ERR Client sent AUTH, but no password is set
- redis在linux下使用客户端
- linux开启redis端口的防火墙
- sql解释执行顺序 调优小常识
- SQL-Server精简安装选项
- 关于pgsql 几个操作符的效率测试比较
- mysql 创建函数 error Code: 1227. Access denied;
- mysql 创建函数 error Code: 1227. Access denied;
- mysql 创建函数 error Code: 1227. Access denied;
- (转)MongoDB 3.0 WT引擎参考配置文件
- (转)mongodb常用命令脚本化-自动化运维
- 利用 ThreadLocal获取或者关闭SqlSession对象,实现同一线程为同一SqlSession
- percona和mariadb的审计插件