SELECT...FOR UPDATE 語句的語法如下:
SELECT ... FOR UPDATE [OF column_list][WAIT n|NOWAIT][SKIP LOCKED];
其中:
OF 子句用于指定即將更新的列,即鎖定行上的特定列。
WAIT 子句指定等待其他用戶釋放鎖的秒數(shù),防止無限期的等待。
“使用FOR UPDATE WAIT”子句的優(yōu)點如下:
-
。狈乐篃o限期地等待被鎖定的行;
。苍试S應(yīng)用程序中對鎖的等待時間進行更多的控制。
。硨τ诮换ナ綉(yīng)用程序非常有用,因為這些用戶不能等待不確定
。 若使用了skip locked,則可以越過鎖定的行,不會報告由wait n 引發(fā)的‘資源忙’異常報告
示例:
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');
現(xiàn)在執(zhí)行如下操作:
在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在執(zhí)行時,永遠處于等待狀態(tài),除非窗口1中sql被提交或回滾。
如何才能讓sql2不等待或等待指定的時間呢? 我們再運行sql3
3. select * from t where a='1' for update nowait; 則在執(zhí)行此sql時,直接報資源忙的異常。
若執(zhí)行 select * from t where a='1' for update wait 6; 則在等待6秒后,報 資源忙的異常。
如果我們執(zhí)行sql4
4. select * from t where a='1' for update nowait skip Locked; 則執(zhí)行sql時,即不等待,也不報資源忙異常。
現(xiàn)在我們看看執(zhí)行如下操作將會發(fā)生什么呢?
在窗口1中執(zhí)行:
select * from t where rownum<=3 nowait skip Locked;
在窗口2中執(zhí)行:
select * from t where rownum<=6 nowait skip Locked;
select for update 也就如此了吧,insert、update、delete操作默認加行級鎖,其原理和操作與select for update并無兩樣。
select for update of,這個of子句在牽連到多個表時,具有較大作用,如不使用of指定鎖定的表的列,則所有表的相關(guān)行均被鎖定,若在of中指定了需修改的列,則只有與這些列相關(guān)的表的行才會被鎖定。 本文出自:億恩科技【1tcdy.com】
服務(wù)器租用/服務(wù)器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM]
|