oracle数据表造成死锁,解决方法

2023-04-12


今天早上查看数据表的时候发现,数据表中多了一条数据(这条数据不应该存在),像往常一样用delete where语句删除这条语句,中间卡了一下,然后一直显示正在执行中



先前也遇到过类似的情况,但是那时是因为,我删除数据没有提交事务,这次不一样,删除不了,一直卡在这里,点击取消后,有没有事务的提交与回滚。开 始怀疑是因为其它的人正在操作了这张数据表,造成了琐表,就等了一段时间,后来发现还是这样的情况,没办法只好百度找解决办法,问题来了到底是琐表造成的 原因,还是另有其它的原因呢?出现这种情况,大致可以分为几种:


1.因为数据量过大,造成数据删除缓慢


2.sql语句使用了for update,没有提交事务


3.其它的人正在操作这张数据表,造成琐表


排除1,2,解决办法找到琐表原因,结束进程。


一下来自百度-----------------------------


解决办法


-- 查出被锁的表,和锁住这个表的会话ID






1. select a.session_id ,b.* from v$locked_object a,all_objects b  
2. where a.object_id=b.object_id











-- 查出对应的SQL语句







    1. select vs.SQL_TEXT,vsess.sid,vsess.SERIAL#,vsess.MACHINE,vsess.OSUSER  
    2. ,vsess.TERMINAL,vsess.PROGRAM,vs.CPU_TIME,vs.DISK_READS  
    3. from v$sql vs,v$session vsess  
    4. where vs.ADDRESS=vsess.SQL_ADDRESS  
    5. and vsess.sid=(上面查出来的会话ID)





    --查看是哪个session引起的



    1. 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;





    --杀进程






    1. ALTER SYSTEM KILL SESSION '查出的SID,查出的SERIAL#';  ---上面这条语句可以查到sid以及serial





    ok,现在问题搞定了


    本文仅代表作者观点,版权归原创者所有,如需转载请在文中注明来源及作者名字。

    免责声明:本文系转载编辑文章,仅作分享之用。如分享内容、图片侵犯到您的版权或非授权发布,请及时与我们联系进行审核处理或删除,您可以发送材料至邮箱:service@tojoy.com