查看哪个表被锁
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
这种情况叫死锁,与网络质量无关.
最大的可能就是程序的原因.
如A进程修改a表的某条记录,修改完a表后,会继续修改b表的某条记录,然后提交事务.
这个时候,B进程在修改b表的那条记录,修改完后要去修改a表的那条记录,然后提交事务.
这样,当A修改完a尚未修改b,B修改完b尚未修改a的时候,就可能出现B进程等待A进程提交事务,A进程又在等待B进程提交事务,两个进程一直在等.
所以死锁就出现了.
①.、查看是否有被锁的表: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.
共享锁 独占锁,
行共享锁 ,行独占锁,表共享锁,表独占锁
①.、在sql语句后面加上for update可以获得行锁.
---
以上,希望对你有所帮助.