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