今天无意中发现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#