SqlServer 查看死锁的进程

来源:互联网 发布:软件部职责要求 编辑:程序博客网 时间:2024/05/16 13:47

搞sqlsever 好多年, 从来没锁过表, 今天终于遇到了..
幸好是开发期.生产期就麻烦了.
百度了一下.
后来解决了.
需要两个工具, 一个是SQLServer自带的manage 客户端
这里写图片描述

这个工具, 用来查看一些当时的运行状态.和干掉进程.
但是这个工具无法查看是哪个表被锁住了. 也无法知道是哪个进程和sql导致了锁进程. 只能查看一些其它的信息.

至于如何查看死锁的表, 需要用到下面的sql. 然后根据查出来的 进程id 去上面的工具中查看详细信息..

查看被锁表:

select request_session_id spid,OBJECT_NAME(resource_associated_entity_id) tableName
from sys.dm_tran_locks where resource_type=’OBJECT’

spid 锁表进程
tableName 被锁表名

解锁:

declare @spid int
Set @spid = 92 –锁表进程
declare @sql varchar(1000)
set @sql=’kill ‘+cast(@spid as varchar)
exec(@sql)