Oracle锁表、解锁、批量解锁表

来源:互联网 发布:陈都灵知乎 编辑:程序博客网 时间:2024/06/04 22:14

1、查询被锁表的SQL:

select object_name,machine,s.sid,s.serial#
from v$locked_object l,dba_objects o ,v$session s
where l.object_id = o.object_id and l.session_id=s.sid;
2、查看哪个进程锁的
SELECT sid, serial#, username, status, osuser FROM v$session  where serial# = '11016'
3、杀掉这个进程 
alter system kill session '52,35022'; (SID,serial#)
4、批量杀死进程
declare cursor mycur is  
select b.sid,b.serial#  
  from v$locked_object a,v$session b  
  where a.session_id = b.sid group by b.sid,b.serial#;  
  
begin  
  for cur in mycur  
    loop    
     execute immediate ( 'alter system  kill session  '''||cur.sid || ','|| cur.SERIAL# ||''' ');  
     end loop;  
end; 


0 0
原创粉丝点击