当前位置: 首页 > news >正文

数据库死锁查询SQL

Oracle

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

  • SELECT子句:指定了查询要返回的列。这里选择了v$ session视图中的username(会话的用户名)、serial#(会话的序列号,用于唯一标识一个会话内的操作序列)、lockwait(会话当前是否在等待某个锁)、status(会话的状态)、machine(会话连接的机器名)、program(启动会话的程序名),以及v$ locked_object视图中的object_id(被锁定的对象ID)和session_id(持有锁的会话ID,注意这里的session_id在v$locked_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。这个条件确保了只有那些当前持有锁的会话的信息才会被包含在查询结果中。
--查看进程
SELECTs.username,l.object_id,l.session_id,s.serial#,s.lockwait,s.status,s.machine,s.program 
FROMv$session s,v$locked_object l 
WHEREs.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锁通常指的是对数据库表或索引等对象的锁。
SELECTrequest_session_id spid,OBJECT_NAME( resource_associated_entity_id ) tableName 
FROMsys.dm_tran_locks 
WHEREresource_type = 'OBJECT'
http://www.lryc.cn/news/432925.html

相关文章:

  • vLLM (4) - LLMEngine上篇
  • Java重修笔记 第五十天 HashSet 和 TreeSet 的去重机制比较
  • 提前购|基于SSM+vue的创新型产品提前购平台(源码+数据库+文档)
  • 上海市计算机学会竞赛平台2024年7月月赛丙组求和问题
  • 【LVI-SAM】激光雷达点云处理特征提取LIO-SAM 之FeatureExtraction实现细节
  • [数据集][目标检测]血细胞检测数据集VOC+YOLO格式2757张4类别
  • opencart journal 3 在价格前添加文本prefix
  • c++ string类的模拟实现的注意事项
  • Unity3D中控制3D场景中游戏对象显示层级的详解
  • 代码执行漏洞-Log4j2漏洞 vulhub CVE-2021-44228
  • uniapp / uniapp x UI 组件库推荐大全
  • 花8000元去培训机构学习网络安全值得吗,学成后就业前景如何?
  • PhpStorm 下调试功能配置
  • MVC(Model-View-Controller)和MVVM(Model-View-ViewModel)
  • 【H2O2|全栈】关于HTML(4)HTML基础(三)
  • 关于找不到插件 ‘org.springframework.boot:spring-boot-maven-plugin:‘的解决方案
  • 深入RabbitMQ世界:探索3种队列、4种交换机、7大工作模式及常见概念
  • 将目标检测模型导出到C++|RT-DETR、YOLO-NAS、YOLOv10、YOLOv9、YOLOv8
  • 【Windows】解决新版 Edge 浏览器开机自启问题(简单有效)
  • 如何给3D人物换衣服CC4
  • 如何对列表、字符串进行分组
  • 【GEE代码实例教程详解:NDVI时间序列趋势分析】
  • 51单片机-DS1302(RTC实时时钟芯片)
  • FreeRTOS学习笔记—②RTOS的认识及任务管理篇
  • 【C++从练气到飞升】22---C++中的异常
  • 前端:HTML、CSS、JS、Vue
  • RocksDB简介
  • [VC] Visual Studio中读写权限冲突
  • ChatGPT3.5/4.0新手使用手册,国内中文版使用教程
  • 基于MicroPython的ESP8266与超声波传感器设计方案