数据库卡顿 sp_lock和sys.dm_tran_locks的用法

sp_lock和sys.dm_tran_locks的用法

一、总结

1.网址

https://docs.microsoft.com/zh-cn/sql/relational-databases/system-stored-procedures/sp-lock-transact-sql?redirectedfrom=MSDN&view=sql-server-2017(sp_lock)
https://docs.microsoft.com/zh-cn/sql/relational-databases/system-dynamic-management-views/sys-dm-tran-locks-transact-sql?view=sql-server-2017(sys.dm_tran_locks)

2.查出结果具体含义参考官方文档。

3.每个锁会占用96字节的内存,如果有大量的小粒度锁,则会占据大量的内存。

二、用到的SQL

1.根据object_id查看对象名称
命令:select OBJECT_NAME(245575913)
           SELECT OBJECT_ID('run.dbo.T1')

   

 2.查询所有的锁

命令:exec sp_lock

Type值的选项含义:

  KEY:索引内保护可串行事务中一系列键的锁

  PAG:数据页或索引页的锁

  EXT:对某区的锁

3.查询指定进程的锁

命令:exec sp_lock 55

 4.根据系统视图查询指定进程的锁

命令:select * from sys.dm_tran_locks where request_session_id=55

 5.显示某个库的锁信息,参数是dbid

命令:SELECT resource_type, resource_associated_entity_id,
request_status, request_mode,request_session_id,
resource_description
FROM sys.dm_tran_locks
WHERE resource_database_id = 5

6.显示阻塞信息
命令:SELECT
t1.resource_type,
t1.resource_database_id,
t1.resource_associated_entity_id,
t1.request_mode,
t1.request_session_id,
t2.blocking_session_id
FROM sys.dm_tran_locks as t1
INNER JOIN sys.dm_os_waiting_tasks as t2
ON t1.lock_owner_address = t2.resource_address;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值