(select sql_hash_value from v$session where sid in
(select session_id from v$locked_object))
四、死鎖的解決方法
一般情況下,只要將產生死鎖的語句提交就可以了,但是在實際的執行過程中。使用者可
能不知道產生死鎖的語句是哪一句。可以將程式關閉並重新啟動就可以了。
經常在oracle的使用過程中碰到這個問題,所以也總結了一點解決方法。
1)查詢死鎖的程序:
from v$locked_object l,v$session s where l.session_id=s.sid;
2)kill掉這個死鎖的程序:
alter system kill session 『sid,serial#』; (其中sid=l.session_id)
3)如果還不能解決:
select pro.spid from v$session ses,v$process pro where ses.sid=xx and ses.paddr=pro.addr;
其中sid用死鎖的sid替換: exit
ps -ef|grep spid
b.serial#, c.oracle_username,c.os_user_name,c.process,
''''||c.session_id||','||b.serial#||''''
from v$sql a, v$session b, v$locked_object c
where a.hash_value = b.sql_hash_value and
b.sid = c.session_id
**:
Oracle中檢查死鎖
select v session.sid,v session.serial v process.spid,rtrim object type object type,rtrim owner object name object name,decode lmode,0,none 1,null 2,ro...
oracle死鎖檢查方法
用dba登陸 sqlplus nolog conn as sysdba select username,lockwait,status,machine,program from v session where sid in select session id from v locked object...
SQL檢查死鎖情況
create procedure sp who lock asbegin declare spid intdeclare blk intdeclare count intdeclare index intdeclare lock tinyint set lock 0 create table tem...