1. 程式人生 > >[Oracle]如何觀察Table 的各種Lock 之間的沖突

[Oracle]如何觀察Table 的各種Lock 之間的沖突

table tab 阻塞 select 在那 我們 如何 rom sel

[Oracle]如何觀察Table 的各種Lock 之間的沖突


舉例:

Session#15 創建表:

SID 15
==============
create table t1 (c1 number)
partition by range(c1)
(partition p1 values less than(‘11‘),
partition p2 values less than(‘21‘),
partition p3 values less than(‘31‘)
)
/

Session#15 對表給予最大限度的鎖定(exclusive)

lock table t1 in exclusive mode; (T1 X(6) lock)


Session#137 進行其他操作(alter table add partition)

SID 137
==============
alter table t1 add partition p4 values less than (‘41‘); ( T1 S(4) lock, T1 X(60 無法共容,所以被阻塞,會一直停在那裏)


查看鎖的狀況

SYS> select * from v$locked_object;

XIDUSN XIDSLOT XIDSQN OBJECT_ID SESSION_ID ORACLE_USERNAME OS_USER_NAME PROCESS LOCKED_MODE
---------- ---------- ---------- ---------- ---------- ------------------------------ ------------------------------ ------------------------ -----------
0 0 0 87656 15 JIMMY ora11204 698 6
3 13 1056 87656 137 JIMMY ora11204 854 0
3 13 1056 18 137 JIMMY ora11204 854 3


這時我們可以執行其他操作,反正大家都被最大級別的 Exclusive 鎖所阻塞,這時候就可以看看他們所執行的 lock 的 locked_mode,
看各種操作的鎖類型是否相容。

SID#141
==============
insert into t1 values(28);

SYS> select * from v$locked_object;

XIDUSN XIDSLOT XIDSQN OBJECT_ID SESSION_ID ORACLE_USERNAME OS_USER_NAME PROCESS LOCKED_MODE
---------- ---------- ---------- ---------- ---------- ------------------------------ ------------------------------ ------------------------ -----------
6 23 1234 87659 141 JIMMY ora11204 927 3
6 23 1234 87656 141 JIMMY ora11204 927 3
...

[Oracle]如何觀察Table 的各種Lock 之間的沖突