关于Oracle 数据库update 卡死的问题

来源:互联网 发布:编曲的软件 编辑:程序博客网 时间:2024/04/28 04:28

今天做eclipse项目的小修改,发现以前可以运行的项目部分今天总是卡死,开始以为是数据库没有关闭连接,导致连接堵塞,后来仔细一看每个都有关闭链接。下断点调试发现是在update的时候出问题,程序卡死在update上面。我用plsql在数据库中查询同样是卡死状态,换一条数据能够正常执行。google了一下找到问题出现的原因。
由于在执行update的时候,当程序已经执行了executeupdate 但是还没有提交事务 commit ,Oracle自动锁住该条记录。

可以通过以下办法解决: 
先查询锁定记录 
Sql代码  
SELECT s.sid, s.serial# FROM v$locked_object lo, dba_objects ao, v$session s WHERE ao.object_id = lo.object_id AND lo.session_id = s.sid;  
 
然后删除锁定记录 
Sql代码  
ALTER system KILL session 'SID,serial#';    

0 0