關於oracle的行級鎖

2021-08-30 05:54:52 字數 1910 閱讀 3890

在oracle中,行級鎖只對使用者正在訪問的行進行鎖定。

如果該使用者正在修改某行,那麼其他使用者就可以更新同一表中該行之外的資料。

行級鎖是一種排他鎖,防止其他事務修改此行,[color=red]但是不會阻止讀取此行的操作[/color]。

在使用insert、update、delete 和select…for update 等語句時,oracle 會自動應用行級鎖鎖定。select...for update 語句允許使用者每次選擇多行記錄進行更新,這些記錄會被鎖定,且只能由發起查詢的使用者進行編輯。只有在回滾或提交事務之後,鎖定才會釋放,其他使用者才可以編輯這些記錄。

select...for update 語句的語法如下:

select ... for update [of column_list][wait n|nowait][skip locked];

其中:of 子句用於指定即將更新的列,即鎖定行上的特定列。

wait 子句指定等待其他使用者釋放鎖的秒數,防止無限期的等待。

「使用for update wait」子句的優點如下:

1防止無限期地等待被鎖定的行;

2允許應用程式中對鎖的等待時間進行更多的控制。

3對於互動式應用程式非常有用,因為這些使用者不能等待不確定

4 若使用了skip locked,則可以越過鎖定的行,不會報告由wait n 引發的『資源忙』異常報告

示例:

create table t(a varchar2(20),b varchar2(20));

insert into t values('1','1');

insert into t values('2','2');

insert into t values('3','3');

insert into t values('4','4');

現在執行如下操作:

在plsql develope中開啟兩個sql視窗,

在1視窗中執行sql

select * from t where a='1' for update;

在2視窗中執行sql1

1. select * from t where a='1'; 這一點問題也沒有,因為行級鎖不會影響純粹的select語句

再執行sql2

2. select * from t where a='1' for update; 則這一句sql在執行時,永遠處於等待狀態,除非視窗1中sql被提交或回滾。

如何才能讓sql2不等待或等待指定的時間呢? 我們再執行sql3

3. select * from t where a='1' for update nowait; 則在執行此sql時,直接報資源忙的異常。

若執行 select * from t where a='1' for update wait 6; 則在等待6秒後,報 資源忙的異常。

如果我們執行sql4

4. select * from t where a='1' for update nowait skip locked; 則執行sql時,即不等待,也不報資源忙異常。

現在我們看看執行如下操作將會發生什麼呢?

在視窗1中執行:

select * from t where rownum<=3 nowait skip locked;

在視窗2中執行:

select * from t where rownum<=6 nowait skip locked;

select for update 也就如此了吧,insert、update、delete操作預設加行級鎖,其原理和操作與select for update並無兩樣。

select for update of,這個of子句在牽連到多個表時,具有較大作用,如不使用of指定鎖定的表的列,則所有表的相關行均被鎖定,若在of中指定了需修改的列,則只有與這些列相關的表的行才會被鎖定。

關於oracle的行級鎖

在oracle中,行級鎖只對使用者正在訪問的行進行鎖定。如果該使用者正在修改某行,那麼其他使用者就可以更新同一表中該行之外的資料。行級鎖是一種排他鎖,防止其他事務修改此行,但是不會阻止讀取此行的操作。在使用insert update delete 和select for update 等 語句時,o...

關於oracle的行級鎖

在oracle中,行級鎖只對使用者正在訪問的行進行鎖定。如果該使用者正在修改某行,那麼其他使用者就可以更新同一表中該行之外的資料。行級鎖是一種排他鎖,防止其他事務修改此行,但是不會阻止讀取此行的操作 在使用insert update delete 和select for update 等語句時,or...

關於oracle的行級鎖

在oracle中,行級鎖只對使用者正在訪問的行進行鎖定。如果該使用者正在修改某行,那麼其他使用者就可以更新同一表中該行之外的資料。行級鎖是一種排他鎖,防止其他事務修改此行,但是不會阻止讀取此行的操作。在使用insert update delete 和select for update 等 語句時,o...