system kill session 「sid,serial#」;或者使用相關操做系統kill進程的命令,如UNIX下kill -9 sid,或者使用其它工具殺掉死鎖進程。sql
select t2.username, t2.sid, t2.serial#, t3.object_name, t2.OSUSER, t2.MACHINE, t2.PROGRAM, t2.LOGON_TIME, t2.COMMAND, t2.LOCKWAIT, t2.SADDR, t2.PADDR, t2.TADDR, t2.SQL_ADDRESS, t1.LOCKED_MODE from v$locked_object t1, v$session t2, dba_objects t3 where t1.session_id = t2.sid and t1.object_id = t3.object_id order by t2.logon_time;
上面這條SQL語句用到了Oracle的兩個視圖和一個表,分別是v$locked_object、v$session、dba_objects
: v$locked_object
視圖中記錄了全部session中的全部被鎖定的對象信息。 v$session
視圖記錄了全部session的相關信息。 dba_objects
爲oracle用戶對象及系統對象的集合,經過關聯這張表可以獲取被鎖定對象的詳細信息。數據庫
說明:
username:oracle用戶名
sid:進程號
serial#:序列號
object_name:表名
osuser:操做系統用戶名
machine:機器名
program:操做工具
logon_time:登錄時間
lockwait:表示當前這張表是否正在等待其餘用戶解鎖這張表
locked_mode:鎖表模式(下面詳細說明)session
經過第一步查出來的信息找到被鎖的表以後執行以下語句解鎖該表:oracle
alter system kill session 'sid,seial#';
注意:sid和seial#就是第一步中查詢出來的進程號和序列號。工具
eg:解除第一步中表的鎖ui
alter system kill session '10,15';
v$locked_object
中的LOCKED_MODE字段表示鎖的模式,oracle中鎖的模式有以下幾種:
0:none
1:null 空
2:Row-S 行共享(RS):共享表鎖,sub share
3:Row-X 行獨佔(RX):用於行的修改,sub exclusive
4:Share 共享鎖(S):阻止其餘DML操做,share
5:S/Row-X 共享行獨佔(SRX):阻止其餘事務操做,share/sub exclusive
6:exclusive 獨佔(X):獨立訪問使用,exclusivespa
數字越大鎖級別越高, 影響的操做越多。操作系統
1級鎖有:Select,有時會在v$locked_object出現。
2級鎖有:Select for update,Lock For Update,Lock Row Share
select for update當對話使用for update子串打開一個遊標時,全部返回集中的數據行都將處於行級(Row-X)獨佔式鎖定,其餘對象只能查詢這些數據行,不能進行update、delete或select for update操做。
3級鎖有:Insert, Update, Delete, Lock Row Exclusive
沒有commit以前插入一樣的一條記錄會沒有反應, 由於後一個3的鎖會一直等待上一個3的鎖, 咱們必須釋放掉上一個才能繼續工做。
4級鎖有:Create Index, Lock Share
locked_mode爲2,3,4不影響DML(insert,delete,update,select)操做, 但DDL(alter,drop等)操做會提示ora-00054錯誤。
00054, 00000, 「resource busy and acquire with NOWAIT specified」
// *Cause: Resource interested is busy.
// *Action: Retry if necessary.
5級鎖有:Lock Share Row Exclusive
具體來說有主外鍵約束時update / delete … ; 可能會產生4,5的鎖。
6級鎖有:Alter table, Drop table, Drop Index, Truncate table, Lock Exclusiverest