• 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

  • 相关阅读:
    discuz论坛X3升级时 文件下载出现问题,请查看您的服务器网络以及data目录是否有写权限
    discuz管理中心无法登陆
    在Windows 7下面IIS7的安装和 配置ASP的正确方法
    window.open
    linux下的vmware虚拟机如何回收虚拟磁盘空间
    CentOS7 安装lamp 3分钟脚本
    pyhon 编译C++安装需要 c99 模式
    条件判断
    python字符串杂项
    RIPv1&v2
  • 原文地址:https://www.cnblogs.com/pugang/p/13275696.html
Copyright © 2020-2023  润新知