ORACLE数据库巡检SQL脚本--4、检查锁阻塞

定位数据库中因锁资源占用导致的"阻塞者"与"等待者"会话,是排查锁等待性能问题的核心语句。

一、SQL脚本

sql 复制代码
--检查锁阻塞
SELECT DECODE(REQUEST, 0, '阻塞者:', '等待者:') || SID AS 会话标识,
       ID1 AS 锁资源标识1,
       ID2 AS 锁资源标识2,
       LMODE AS 持有锁模式,
       REQUEST AS 请求锁模式,
       TYPE AS 锁类型
  FROM V$LOCK
 WHERE (ID1, ID2, TYPE) IN (SELECT ID1, ID2, TYPE FROM V$LOCK WHERE REQUEST > 0) -- 筛选存在锁请求的资源
 ORDER BY ID1, REQUEST;

二、脚本说明

该脚本用于识别数据库中的锁依赖关系

  • 标记"阻塞者":持有锁资源、导致其他会话等待的会话;
  • 标记"等待者":因锁资源被占用而处于等待状态的会话;
  • 定位锁资源:通过ID1/ID2/TYPE确定具体被争夺的锁资源。
字段 含义 巡检关注点
会话标识 会话ID,前缀标注"阻塞者:"/"等待者:" 直接区分阻塞方与被阻塞方
锁资源标识1 锁对应的核心资源标识(如表ID、行ID) 相同的锁资源标识1+2+类型表示同一锁资源
锁资源标识2 锁资源的子标识 配合前两个字段定位具体锁对象
持有锁模式 会话当前持有的锁模式(0=无锁,1=共享锁,6=排他锁等) 阻塞者的该值为非0(持有锁)
请求锁模式 会话请求的锁模式(0=无请求,非0=请求对应锁) 等待者的该值>0(正在请求锁)
锁类型 锁的类型(如TM=表锁,TX=事务锁) 常见阻塞类型为TX(事务锁)或TM(表锁)

三、注意事项

1、如何识别锁阻塞问题

  1. 区分阻塞关系

    • 前缀为"阻塞者:"的会话,是持有锁的"源头";
    • 前缀为"等待者:"的会话,是被阻塞的会话;
    • 同一组锁资源标识1+2+类型的记录,对应同一锁资源的阻塞链。
  2. 判断严重程度

    • 若"等待者"数量多,说明该锁资源的阻塞情况已影响多个业务会话;
    • 若锁类型为TX(事务锁),通常是长事务未提交导致的阻塞,需优先处理。

2、阻塞问题的处理建议

  1. 定位阻塞SQL

    通过阻塞者的会话ID(SID)查询其执行的SQL,优化该SQL以缩短事务时间:

    sql 复制代码
    SELECT SQL_TEXT 
    FROM V$SQL 
    WHERE SQL_ID = (SELECT SQL_ID FROM V$SESSION WHERE SID = 阻塞者SID);
  2. 终止阻塞会话

    先查询阻塞者会话的SERIAL#,再终止会话(需谨慎,避免影响正常业务):

    sql 复制代码
    -- 第一步:查询阻塞者的SERIAL#
    SELECT SERIAL# FROM V$SESSION WHERE SID = 阻塞者SID;
    -- 第二步:终止会话
    ALTER SYSTEM KILL SESSION '阻塞者SID, 对应的SERIAL#';
相关推荐
程序猿乐锅13 小时前
【Tilas|第三篇】多表SQL语句
数据库·经验分享·笔记·学习·mysql
Navicat中国14 小时前
使用 Navicat 导入向导导入 Excel 数据时,系统提示导入成功,表中也能看到数据,但行数统计显示为 0,这是什么原因?
数据库·excel·导入
gmaajt14 小时前
Golang怎么做国际化多语言_Golang i18n教程【核心】
jvm·数据库·python
折哥的程序人生 · 物流技术专研14 小时前
从“卡死”到“秒过”:WMS销售数据跨库回填的极限优化之旅
数据库·机器学习·oracle
李可以量化14 小时前
DeepSeek 量化交易实战:用标准化提示词模板实现 AI 辅助交易决策
大数据·数据库·人工智能
maqr_11014 小时前
CSS如何利用Sass定义全局阴影方案_通过变量实现统一CSS风格
jvm·数据库·python
m0_6138562915 小时前
uni-app怎么做类似于美团的商家评价星级 uni-app五星评分组件制作【实战】
jvm·数据库·python
Irene199115 小时前
大数据开发语境下,SQL 模式名,映射关系 - - 概念理解
大数据·数据库·sql
顾随15 小时前
(二)kettle--输入与输出
javascript·数据库·kettle
2401_8330336215 小时前
如何修复固定定位头部容器中悬浮下拉菜单的错位问题
jvm·数据库·python