日期:2014-05-16  浏览次数:20480 次

oracle数据中删除数据时提示“记录被另一个用户锁住”

oracle数据中删除数据时提示“记录被另一个用户锁住”
2011年8月23日 星期二 17时16分

?

解决方法:

?

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

select object_id,session_id,locked_mode from v$locked_object;

?

或者用以下命令: select b.owner,b.object_name,l.session_id,l.locked_mode 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#';

?

?

?

?

?