Oracle中V$LOCK 视图的使用小结

 更新时间:2025年06月15日 09:52:58   作者:文牧之  
V$LOCK是Oracle关键动态视图,用于诊断事务、表级及系统级锁冲突,结合其他视图分析阻塞与死锁问题,本文就来介绍一下Oracle V$LOCK 视图的使用,感兴趣的可以了解一下

V$LOCK 是 Oracle 数据库中最重要的动态性能视图之一,用于显示当前数据库中锁的持有和等待情况。

一、V$LOCK 视图结构

列名数据类型描述
SIDNUMBER持有或等待锁的会话标识符
TYPEVARCHAR2(2)锁类型标识符
ID1NUMBER锁标识符1(含义取决于锁类型)
ID2NUMBER锁标识符2(含义取决于锁类型)
LMODENUMBER锁模式(当前持有的模式)
REQUESTNUMBER请求的锁模式
CTIMENUMBER锁已持有或等待的时间(秒)
BLOCKNUMBER是否阻塞其他会话(1=阻塞,0=不阻塞)

二、主要锁类型(TYPE字段)

1. 基本锁类型

类型描述
TX事务锁(行级锁)
TMDML锁(表级锁)
UL用户自定义锁(DBMS_LOCK创建)

2. 系统级锁类型

类型描述
ST空间事务锁
TT临时表锁
SQ序列锁
CF控制文件锁

三、锁模式(LMODE/REQUEST)

Oracle 锁模式数值定义:

锁模式描述
0None无锁
1Null (N)空模式
2Row-S (SS)行共享
3Row-X (SX)行排他
4Share (S)共享
5S/Row-X (SSX)共享行排他
6Exclusive (X)排他

四、ID1 和 ID2 的含义

1. TX 锁(事务锁)

  • ID1:Undo 段号 + 事务槽号(USN.SLT)
  • ID2:事务序列号(WRAP)

2. TM 锁(表锁)

  • ID1:被锁定对象的 OBJECT_ID
  • ID2:通常为 0

3. UL 锁(用户锁)

  • ID1:DBMS_LOCK.ALLOCATE_UNIQUE 分配的锁ID
  • ID2:通常为 0

五、实用查询示例

1. 查看所有锁信息

SELECT * FROM v$lock ORDER BY ctime DESC;

2. 查找阻塞会话

SELECT 
  l1.sid AS "阻塞会话ID",
  s1.username AS "阻塞用户",
  s1.osuser AS "阻塞OS用户",
  s1.machine AS "阻塞机器",
  l2.sid AS "被阻塞会话ID",
  s2.username AS "被阻塞用户",
  l1.type AS "锁类型",
  DECODE(l1.type,
    'TX', '事务锁',
    'TM', '表锁',
    'UL', '用户锁',
    l1.type) AS "锁描述",
  l1.ctime AS "持有时间(秒)"
FROM v$lock l1, v$lock l2, v$session s1, v$session s2
WHERE l1.block = 1 
AND l2.request > 0
AND l1.id1 = l2.id1
AND l1.id2 = l2.id2
AND l1.sid = s1.sid
AND l2.sid = s2.sid;

3. 查询特定对象的锁

SELECT l.sid, s.username, s.status, l.type, l.lmode, l.ctime, o.object_name
FROM v$lock l, dba_objects o, v$session s
WHERE l.id1 = o.object_id(+)
AND l.type = 'TM'
AND l.sid = s.sid
AND o.object_name = 'EMPLOYEES';

六、锁诊断与问题解决

1. 常见锁问题

  • TX锁等待:最常见的事务冲突
  • TM锁冲突:DDL与DML操作冲突
  • 死锁:ORA-00060错误

2. 解锁方法

-- 1. 查找阻塞会话
SELECT sid, serial#, username FROM v$session 
WHERE sid IN (SELECT blocking_session FROM v$session WHERE blocking_session IS NOT NULL);

-- 2. 终止会话
ALTER SYSTEM KILL SESSION 'sid,serial#' IMMEDIATE;

V$LOCK 视图是诊断 Oracle 锁问题的关键工具,结合 V$SESSION 和 V$LOCKED_OBJECT 等视图可以全面分析锁情况。

到此这篇关于Oracle中V$LOCK 视图的使用小结的文章就介绍到这了,更多相关Oracle V$LOCK 视图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Oracle分页查询的实例详解

    Oracle分页查询的实例详解

    这篇文章主要介绍了Oracle分页查询的实例详解的相关资料,希望通过本文能帮助到大家实现理解这部分内容,需要的朋友可以参考下
    2017-10-10
  • Oracle解锁表、包、用户、杀会话、停job的方法实现

    Oracle解锁表、包、用户、杀会话、停job的方法实现

    本文主要介绍了Oracle解锁表、包、用户、杀会话、停job的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • Oracle中实现一次插入多条数据详细代码举例

    Oracle中实现一次插入多条数据详细代码举例

    公司的项目,有个功能每次使用需要向数据库插入很多数据,这里给大家总结下,这篇文章主要给大家介绍了Oracle中实现一次插入多条数据的相关资料,文中通过图文及代码介绍的非常详细,需要的朋友可以参考下
    2024-06-06
  • ORACLE正则匹配查询LIKE查询多个值检索数据库对象

    ORACLE正则匹配查询LIKE查询多个值检索数据库对象

    这篇文章主要介绍了ORACLE正则匹配查询,LIKE查询多个值检索数据库对象,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • Oracle查看正在执行的sql语句的方法大全

    Oracle查看正在执行的sql语句的方法大全

    这篇文章主要介绍了Oracle查看正在执行的sql语句的方法大全,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起来学习吧
    2024-04-04
  • oracle 11g数据库安全加固注意事项

    oracle 11g数据库安全加固注意事项

    这篇文章主要介绍了oracle11g数据库安全加固须谨慎 ,需要的朋友可以参考下
    2015-08-08
  • Oracle ORA-00904:标识符无效解决方法(太坑了!!)

    Oracle ORA-00904:标识符无效解决方法(太坑了!!)

    最近执行sql时oracle报错ORA-00904:标识符无效,所以这篇文章主要给大家介绍了关于Oracle ORA-00904:标识符无效解决方法的相关资料,需要的朋友可以参考下
    2022-10-10
  • oracle数据库的DBMS_LOB.SUBSTR函数使用

    oracle数据库的DBMS_LOB.SUBSTR函数使用

    DBMS_LOB.SUBSTR用于从Oracle的CLOB/NCLOB等大对象中提取子字符串,参数包括LOB对象、提取长度和起始位置,下面就一起来了解一下
    2025-06-06
  • Oracle数据库查看与修改内存配置的方法

    Oracle数据库查看与修改内存配置的方法

    在使用Oracle时我们需要关注数据库的内存使用情况,以确保其正确高效地运行,下面这篇文章主要给大家介绍了关于Oracle数据库查看与修改内存配置的相关资料,需要的朋友可以参考下
    2023-11-11
  • Oracle基础:程序中调用sqlplus的方式

    Oracle基础:程序中调用sqlplus的方式

    今天小编就为大家分享一篇关于Oracle基础:程序中调用sqlplus的方式,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12

最新评论