oracle查看数据库锁,诊断锁的来源及类型

1、查看数据库锁,诊断锁的来源及类型:
  select object_id,session_id,locked_mode from v$locked_object;
或者用以下命令:
select b.owner,b.object_name,l.session_id,l.locked_mode
from v$locked_object l, dba_objects b
where b.object_id=l.object_id

集群环境可能使用gv视图才能查出

SELECT object_name, machine, s.sid, s.serial# FROM gv$locked_object l, dba_objects o, gv$session s 
WHERE l.object_id = o.object_id AND l.session_id = s.sid;

SELECT object_name, machine, s.sid, s.serial# FROM gv$locked_object l, dba_objects o, gv$session s WHERE l.object_id = o.object_id AND l.session_id = s.sid;

2、找出数据库的serial#,以备杀死:
   select t2.username,t2.sid,t2.serial#,t2.logon_time
from v$locked_object t1,v$session t2
where t1.session_id=t2.sid order by t2.logon_time;

3、杀死该session
  alter system kill session 'sid,serial#'

4、查询更详细的锁表信息

select 'exec superkill(' || sess.sid || ',' || sess.serial# || ',' ||
         (select inst_id from gv$session  where username = 'SUN_EGRANT_PRO' and sid = sess.sid and serial# = sess.serial#) || ');',
         sess.sid,
         sess.TIME_REMAINING_MICRO, sess.TIME_SINCE_LAST_WAIT_MICRO,
         sess.PREV_EXEC_START, sess.EVENT,
         t2.SQL_TEXT,
         lo.os_user_name
    from v$locked_object lo, dba_objects ao, v$session sess,v$sql t2
   where ao.object_id = lo.object_id
     and lo.session_id = sess.sid
     and sess.SQL_ID = t2.sql_id;

5、由于某个数据被锁住,但是按上面的语句无法查出,最后DBA用以下语句能查出被某个锁影响了

select decode (request,0, 'Holder:',' Waiter:') ||s.inst_id||':' ||s.sid||','||s.serial# sess,
id1,id2, lmode, request,l.type, ctime,s.sql_id, s.event,s.last_call_et
from gv$lock l,gv$session s
where (id1, id2, l.type) in
(select id1, id2, type from gv$lock where request>0)
and l.sid=s.sid
and l.INST_ID=s.INST_ID
order by id1, ctime desc, request;

以下语句生成命令窗口sql,可以执行杀掉锁

select 'exec superkill('|| s.sid || ',' || s.serial# || ',' ||s.inst_id|| ');',
decode (request,0, 'Holder:',' Waiter:') ||s.inst_id||':' ||s.sid||','||s.serial# sess,
id1,id2, lmode, request,l.type, ctime,s.sql_id, s.event,s.last_call_et,s.LOGON_TIME,t2.SQL_TEXT
from gv$lock l,gv$session s,v$sql t2
where (id1, id2, l.type) in
(select id1, id2, type from gv$lock where request>0)
and l.sid=s.sid
and l.INST_ID=s.INST_ID
and s.SQL_ID=t2.SQL_ID
order by id1, ctime desc, request;

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值