zoukankan      html  css  js  c++  java
  • 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上对应的进程才行。

  • 相关阅读:
    hdu1003 最大连续子序和
    ACM 线性规划
    ACM 概率&&动态规划
    ACM 数论 质因数分解
    ACM 计数
    ACM 概率
    ACM矩形嵌套问题LIS
    ACM 编辑距离
    ACM线性方程
    ACM 错排
  • 原文地址:https://www.cnblogs.com/zt007/p/6045793.html
Copyright © 2011-2022 走看看