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;
查找出来之后,发现有三个对象! alter system kill session '13,52136';
--这里的13是上边查出的sid,52136是查出的serial
然后又出现了一个问题,我再查的时候那个sid为13的session还是一直在,但是状态已经是killed,我再执行 服务器数据库上锁定的资源还是没有释放,这时候我们可以去服务器将该进程杀死! select spid,osuser,s.program from v$session s,v$process p where s.paddr=p.addr and s.sid=13; --spid=5162
|