当前位置:数据库 > Oracle >>

oracle锁数据的问题解决

oracle锁数据的问题解决
 
今天无意中发现oracle数据库中的一条记录不能编辑也不能删除,还以为是程序原因找了很久没有找到问题,后来在网上查了下,发现是oracle锁表引起的,现在把解决方案记录下来,以便以后用~~~
 
锁表查询的代码有以下的形式:
Sql代码  
select count(*) from v$locked_object;  
select * from v$locked_object;  
 
查看哪个表被锁了:
Sql代码  
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引起的:
Sql代码  
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;  
 
最后杀掉对应进程:
Sql代码  
alter system kill session'509,34328';  
 其中509是sid,34328是serial#
 
 
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,