加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Oracle解决锁表问题

发布时间:2020-12-12 13:55:14 所属栏目:百科 来源:网络整理
导读:前言 更新一张表的数据,就几百条,然后特别慢,一直在执行,然后强制退掉,重新执行还是一样,考虑到可能是锁表的问题! 解决 ①首先查找是哪些session被锁: select object_name,machine,s.sid,s.serial# from v$locked_object l,dba_objects o,v$ session

前言

更新一张表的数据,就几百条,然后特别慢,一直在执行,然后强制退掉,重新执行还是一样,考虑到可能是锁表的问题!

解决

①首先查找是哪些session被锁:

select object_name,machine,s.sid,s.serial# from v$locked_object l,dba_objects o,v$session s where l.object_id=o.object_id and l.session_id=s.sid;
  • 1
  • 2
  • 3

查找出来之后,发现有三个对象!
②然后将这三个对象一一杀死:

alter system kill session '13,52136';
--这里的13是上边查出的sid,52136是查出的serial
  • 2

然后又出现了一个问题,我再查的时候那个sid为13的session还是一直在,但是状态已经是killed,我再执行alter system kill session '13,52136';时就报错ORA-00031:session marked for kill(标记要终止的会话)

服务器数据库上锁定的资源还是没有释放,这时候我们可以去服务器将该进程杀死!
首先查出进程号spid:

select spid,osuser,s.program from v$session s,v$process p where s.paddr=p.addr and s.sid=13;   --spid=5162
  • 然后根据查询出的spid来杀死进程
    1. Linux OS:kill -9 5162
    2. Windows OS:orakill mars 5162,其中mars为要杀死进程的实例名!
    在windows下打开cmd,输入命令tasklist /svc可以查看PID为5162的服务名,即实例名!

    这里说下三个概念:

    SPID一一system process id,表示该server process在OS层面的Porcess ID ,即操作系统进程ID
    PID一一Oracle process id
    可以理解为Oracle自己用的,Oracle进程ID
    SID一一SESSION标识,常用于连接其它列
    • 3
    • 4
    • 5

    参考文章:
    ora-00031:session marked for kill处理oracle中杀不掉的锁
    Oracle锁表处理

    (编辑:李大同)

    【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读