Oracle鎖表查詢


第一步:通過管理員權限用戶查詢被鎖表信息

  system kill session “sid,serial#”;或者使用相關操作系統kill進程的命令,如UNIX下kill -9 sid,或者使用其它工具殺掉死鎖進程。

  

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:鎖表模式(下面詳細說明)

第二步:通過擁有管理員權限的用戶解除數據庫中被鎖住的表(SID,SERIAL)

通過第一步查出來的信息找到被鎖的表之后執行如下語句解鎖該表:

alter system kill session 'sid,seial#';
  • 1

注意:sid和seial#就是第一步中查詢出來的進程號和序列號。

eg:解除第一步中表的鎖

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):獨立訪問使用,exclusive

數字越大鎖級別越高, 影響的操作越多。

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 Exclusive


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM