Oracle锁表与解锁

查看锁表语句:

ssh oracle@10.164.197.17
connect / as sysdba

直接连接数据库

sqlplus / as sysdba



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;


方法1:
    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; 

方法2:
    select *   
    from v$session s, v$locked_object l   
    where s.sid = l.SESSION_ID;   


杀掉锁表进程:

    alter system kill session 'SID,SERIAL#';   

  如有記錄則表示有lock,記錄下SID和serial# ,將記錄的ID替換下面的738,1429,即可解除LOCK
  alter system kill session '738,1429';

说明:
使用方法1或者方法2中查询到的SID与SERIAL#(如果没有,则说明没有锁表进程)替换并执行,就可以解除LOCK。


3.如果利用上面的命令杀死一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放,

那么可以在os一级再杀死相应的进程(线程),首先执行下面的语句获得进程(线程)号:

复制代码 代码如下:
select spid, osuser, s.program
from v$session s,v$process p
where s.paddr=p.addr and s.sid=24

(24是上面的sid)

4.在OS上杀死这个进程(线程):

1)在unix上,用root身份执行命令:
#kill -9 12345(即第3步查询出的spid)

2)在windows(unix也适用)用orakill杀死线程,orakill是oracle提供的一个可执行命令,语法为:
orakill sid thread

其中:
sid:表示要杀死的进程属于的实例名
thread:是要杀掉的线程号,即第3步查询出的spid。
例:c:>orakill orcl 12345

总结:oracle会话被锁是经常的。但有时alter system kill session 'sid,serial#';并不能彻底的杀死会话。只能通过杀死OS上对应的进程才行。

原文地址:https://www.cnblogs.com/zt007/p/6045793.html