数据库死锁查询SQL

Oracle

从Oracle数据库的动态性能视图(Dynamic Performance Views)中检索当前被锁定的数据库对象的相关信息,以及持有这些锁的会话(session)的详细信息。具体来说,它连接了v session和vlocked_object两个视图,并通过会话ID(sid)将它们关联起来。

  • SELECT子句:指定了查询要返回的列。这里选择了v session视图中的username(会话的用户名)、serial#(会话的序列号,用于唯一标识一个会话内的操作序列)、lockwait(会话当前是否在等待某个锁)、status(会话的状态)、machine(会话连接的机器名)、program(启动会话的程序名),以及v locked_object视图中的object_id(被锁定的对象ID)和session_id(持有锁的会话ID,注意这里的session_id在vlocked_object中实际是与v session中的sid相对应的)。
  • FROM子句:指定了查询的数据源,即v session s和v locked_object l。这里使用了别名s和l来分别引用这两个视图,以便在查询的其余部分中更简洁地引用它们。
  • WHERE子句:提供了连接v session和v locked_object两个视图的条件,即s.sid = l.session_id。这个条件确保了只有那些当前持有锁的会话的信息才会被包含在查询结果中。
sql 复制代码
--查看进程
SELECT
	s.username,
	l.object_id,
	l.session_id,
	s.serial#,
	s.lockwait,
	s.status,
	s.machine,
	s.program 
FROM
	v$session s,
	v$locked_object l 
WHERE
	s.sid = l.session_id;

--杀掉进程
alter system kill session '70,46413';

SQL Server

从SQL Server的动态管理视图(DMV)sys.dm_tran_locks中检索当前被锁定的数据库对象的信息。具体来说,它检索了当前所有持有对象级别锁(resource_type = 'OBJECT')的会话(或进程)的会话ID(spid,尽管这里使用的是request_session_id,它实际上是会话ID的准确表示)以及这些锁关联到的数据库对象的名称(tableName)。

  • SELECT 子句:指定了查询要返回的列。这里,它选择了request_session_id(通常用作会话ID的别名spid,尽管这不是官方或标准的别名)和通过OBJECT_NAME(resource_associated_entity_id)函数获取的表名(别名为tableName)。OBJECT_NAME函数根据对象的ID(这里是resource_associated_entity_id)返回对象的名称。
  • FROM sys.dm_tran_locks:指定了查询的数据源,即sys.dm_tran_locks动态管理视图。这个视图提供了当前SQL Server实例中所有活动锁的信息,包括锁的类型、锁定的资源、持有锁的会话等。
  • WHERE resource_type = 'OBJECT':这是一个过滤条件,用于限制查询结果只包含那些资源类型为OBJECT的锁。在SQL Server中,OBJECT锁通常指的是对数据库表或索引等对象的锁。
sql 复制代码
SELECT
	request_session_id spid,
	OBJECT_NAME( resource_associated_entity_id ) tableName 
FROM
	sys.dm_tran_locks 
WHERE
	resource_type = 'OBJECT'
相关推荐
头顶秃成一缕光16 分钟前
Redis的主从模式和哨兵模式
数据库·redis·缓存
AIGC大时代18 分钟前
高效使用DeepSeek对“情境+ 对象 +问题“型课题进行开题!
数据库·人工智能·算法·aigc·智能写作·deepseek
博睿谷IT99_20 分钟前
数据库证书可以选OCP认证吗?
数据库·oracle·开闭原则·ocp认证
乐维_lwops32 分钟前
数据库监控 | MongoDB监控全解析
数据库·mongodb·数据库监控
观无32 分钟前
Redis安装及入门应用
数据库·redis·缓存
我的golang之路果然有问题1 小时前
速成GO访问sql,个人笔记
经验分享·笔记·后端·sql·golang·go·database
柏油1 小时前
MySql InnoDB 事务实现之 undo log 日志
数据库·后端·mysql
DolphinScheduler社区2 小时前
白鲸开源WhaleStudio与崖山数据库管理系统YashanDB完成产品兼容互认证
数据库·开源·认证·崖山数据库·白鲸开源
阑梦清川2 小时前
AI超级智能体项目教程(二)---后端项目初始化(设计knif4j接口文档的使用)
java·前端·数据库
hotlinhao2 小时前
ThinkPHP6模型中多组条件逻辑或Or查询的使用
linux·服务器·数据库