Oracle数据库死锁查询

本文介绍了如何在Oracle数据库中检测和分析死锁问题,包括检查死锁的存在、涉及的SQL语句、死锁用户及程序,以及如何确定死锁的相互影响。通过连接到数据库并使用特定SQL查询,可以深入了解和解决死锁状况。

关于对Oracle视图 V$LOCK的学习,看参考: http://www.oracleplus.net/arch/632.html


用system用户登录数据库 conn system/system的密码@IP地址:端口号/数据库实例,执行以下sql检查死锁情况:

检查是否存在死锁

select sess.sid,
       sess.serial#,
       lo.oracle_username,
       lo.os_user_name,
       ao.object_name,
       lo.locked_mode
  from v$locked_object lo, dba_objects ao, v$session sess
 where ao.object_id = lo.object_id
   and lo.session_id = sess.sid;

检查死锁的sql

select sql_text
  from v$sql
 where hash_value in
       (select sql_hash_value
          from v$session
         where sid in (select session_id from v$locked_object));

检查死锁用户的sql

select b.username, b.serial#, d.id1, a.sql_text
  from v$lock d, v$session b, v$sqltext a
 where b.lockwait = d.kaddr
   and a.address = b.sql_address
   and a.hash_value = b.sql_hash_value;

检查死锁用户和程序

select username, lockwait, status, machine, program
  from v$session
 where sid in (select session_id from v$locked_object);

确定谁锁了谁

select s1.username || '@' || s1.machine || ' ( SID=' || s1.sid ||
       ' )  is blocking ' || s2.username || '@' || s2.machine || ' ( SID=' ||
       s2.sid || ' ) ' AS blocking_status
  from v$lock l1, v$session s1, v$lock l2, v$session s2
 where s1.sid = l1.sid
   and s2.sid = l2.sid
   and l1.BLOCK = 1
   and l2.request > 0
   and l1.id1 = l2.id1
   and l2.id2 = l2.id2;

确定链接的sql

select sql_text from v$session v,v$sql s where SID=345 and v.sql_hash_value = s.hash_value;

 

 

评论 5
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值