zoukankan      html  css  js  c++  java
  • Oracle查看锁表和解锁

    --注意权限问题

    1.查看是否有被锁的表:

    select b.owner,b.object_name,a.session_id,a.locked_mode
    from v$locked_object a,dba_objects b

    where b.object_id = a.object_id

    2.查看是哪个进程锁的

    select b.username,b.sid,b.serial#,logon_time
    from v$locked_object a,v$session b

    where a.session_id = b.sid order by b.logon_time

    3.杀掉进程

    alter system kill session 'sid,serial#';

     --------------------------------------------------------------

    首先你要知道表锁住了是不是正常锁?因为任何DML语句都会对表加锁。

    你要先查一下是那个会话那个sql锁住了表,有可能这是正常业务需求,不建议随便KILL session,如果这个锁表是正常业务你把session kill掉了会影响业务的。
    建议先查原因再做决定。

    (1)锁表查询的代码有以下的形式:
    select count(*) from v$locked_object;
    select * from v$locked_object;
    (2)查看哪个表被锁
    select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_objects b where b.object_id = a.object_id;
    (3)查看是哪个session引起的
    select b.username,b.sid,b.serial#,logon_time from v$locked_object a,v$session b where a.session_id = b.sid order by b.logon_time;

    (4)查看是哪个sql引起的
    select b.username,b.sid,b.serial#,c.* from v$locked_object a,v$session b,v$sql c where a.session_id = b.sid
    and b.SQL_ID = c.sql_id and c.sql_id = ''
    order by b.logon_time;

    (5)杀掉对应进程
    执行命令:alter system kill session'1025,41';
    其中1025为sid,41为serial#. 

      (6) 显示用户会话ID不存在 :  

       我遇到的情况是,其实已经执行了kill进程命令,即已经执行了第(5)条,

       但是要等个把小时才生效,在短时间内还是锁表状态,并且报的提示信息是 会话ID不存在,

       可过一段时间再试,表已经解锁了。

    https://www.cnblogs.com/LoveShare/p/11502726.html

    https://blog.csdn.net/jiangyu1013/article/details/76032859

  • 相关阅读:
    c基础
    一维数组,字符数组
    循环结构
    分支结构
    结构体
    Python简介和入门
    Python基础(一)
    Markdown 基础学习
    PyCharm 专业版安装
    Python基础(二)
  • 原文地址:https://www.cnblogs.com/pugang/p/13275696.html
Copyright © 2011-2022 走看看