Oracle锁表与解锁详解数据库

查看锁表语句:

ssh [email protected]
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://blog.ytso.com/4574.html

(0)
上一篇 2021年7月16日
下一篇 2021年7月16日

相关推荐

发表回复

登录后才能评论