sp_lock和sys.dm_tran_locks的用法
09-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;
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· DeepSeek “源神”启动!「GitHub 热点速览」
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· NetPad:一个.NET开源、跨平台的C#编辑器
2021-08-12 MySQL 优化步骤
2021-08-12 忘记Surface Windows密码