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

oracle锁数据的问题解决

今天无意中发现oracle数据库中的一条记录不能编辑也不能删除,还以为是程序原因找了很久没有找到问题,后来在网上查了下,发现是oracle锁表引起的,现在把解决方案记录下来,以便以后用~~~

?

锁表查询的代码有以下的形式:

select count(*) from v$locked_object;
select * from v$locked_object;

?

查看哪个表被锁了:

select b.owner,b.object_name,a.session_id,a.locked_mode
from v$locked_object a,dba_objects b
where b.object_id = a.object_id;

?

查看是哪个session引起的:

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;

?

最后杀掉对应进程:

alter system kill session'509,34328';

?其中509是sid,34328是serial#

?

?

?