oracle 数据库记录被锁定解决办法

来源:V型知识库 | 2016年12月19日 13:44 | 237次浏览 | 分类: 互联网&程序员 作者原创 版权保护

今天在做更新一条oracle数据库表中一条记录的时候发现更新语句执行之后一直卡死,就是无任何反应,也不执行,也没有执行结果,然后上网查询了下完美解决,具体解决办法如下:

1、查看数据库锁,诊断锁的来源及类型: 

select object_id,session_id,locked_mode from v$locked_object;

或者用以下命令: 

from v$locked_object l, dba_objects b 
where b.object_id=l.object_id 
 
SELECT lpad(' ',decode(l.xidusn ,0,3,0))||l.oracle_username User_name, 
o.owner,o.object_name,o.object_type,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 
ORDER BY o.object_id,xidusn DESC

2、找出数据库的serial#,以备杀死: 

select t2.username,t2.sid,t2.serial#,t2.logon_time 
from v$locked_object t1,v$session t2 
where t1.session_id=t2.sid order by t2.logon_time;

3、杀死该session 

alter system kill session 'sid,serial#'

用步骤2中查出来的记录,对应进该语句删除