av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

淺談Oracle行級鎖的特殊用法

Oracle有許多的鎖,各種鎖的效用是不一樣的。下面重點介紹Oracle行級鎖,Oracle行級鎖只對用戶正在訪問的行進(jìn)行鎖定。可以更好的保證數(shù)據(jù)的安全性。

站在用戶的角度思考問題,與客戶深入溝通,找到惠陽網(wǎng)站設(shè)計與惠陽網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:網(wǎng)站設(shè)計制作、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋惠陽地區(qū)。

如果該用戶正在修改某行,那么其他用戶就可以更新同一表中該行之外的數(shù)據(jù)。
Oracle行級鎖是一種排他鎖,防止其他事務(wù)修改此行,但是不會阻止讀取此行的操作。
在使用INSERT、UPDATE、DELETE 和SELECT…FOR UPDATE 等 語句時,Oracle會自動應(yīng)用Oracle行級鎖行級鎖鎖定。SELECT...FOR UPDATE 語句允許用戶每次選擇多行記錄進(jìn)行更新,這些記錄會被鎖定,且只能由發(fā)起查詢的用戶進(jìn)行編輯。只有在回滾或提交事務(wù)之后,鎖定才會釋放,其他用戶才可以編輯這些記錄。
SELECT...FOR UPDATE 語句的語法如下:

 
 
 
  1. SELECT ... FOR UPDATE [OF column_list][WAIT n|NOWAIT][SKIP LOCKED];  

其中:
OF 子句用于指定即將更新的列,即鎖定行上的特定列。
WAIT 子句指定等待其他用戶釋放鎖的秒數(shù),防止無限期的等待。
“使用FOR UPDATE WAIT”子句的優(yōu)點如下:
⒈防止無限期地等待被鎖定的行;
⒉允許應(yīng)用程序中對鎖的等待時間進(jìn)行更多的控制。
⒊對于交互式應(yīng)用程序非常有用,因為這些用戶不能等待不確定
4. 若使用了skip locked,則可以越過鎖定的行,不會報告由wait n 引發(fā)的‘資源忙’異常報告
示例:

 
 
 
  1. create table t(a varchar2(20),b varchar2(20));  
  2. insert into t values('1','1');  
  3. insert into t values('2','2');  
  4. insert into t values('3','3');  
  5. insert into t values('4','4');  

現(xiàn)在執(zhí)行如下操作:
在plsql develope中打開兩個sql窗口,
在1窗口中運(yùn)行sql

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

在2窗口中運(yùn)行sql1

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

2. select * from t where a='1' for update; 則這一句sql在執(zhí)行時,永遠(yuǎn)處于等待狀態(tài),除非窗口1中sql被提交或回滾。
如何才能讓sql2不等待或等待指定的時間呢? 我們再運(yùn)行sql3

3

 
 
 
  1. 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.

 
 
 
  1. select * from t where a='1' for update nowait skip Locke 

d; 則執(zhí)行sql時,即不等待,也不報資源忙異常。
現(xiàn)在我們看看執(zhí)行如下操作將會發(fā)生什么呢?
在窗口1中執(zhí)行:

 
 
 
  1. select * from t where rownum 《3 nowait skip Locked;   

在窗口2中執(zhí)行:

 
 
 
  1. select * from t where rownum《6 nowait skip Locked;   
  2. select for update 

也就如此了吧,insert、update、delete操作默認(rèn)加行級鎖,其原理和操作與select for update并無兩樣。
select for update of,這個of子句在牽連到多個表時,具有較大作用,如不使用of指定鎖定的表的列,則所有表的相關(guān)行均被鎖定,若在of中指定了需修改的列,則只有與這些列相關(guān)的表的行才會被鎖定。


當(dāng)前標(biāo)題:淺談Oracle行級鎖的特殊用法
本文路徑:http://uogjgqi.cn/article/djoegej.html
掃二維碼與項目經(jīng)理溝通

我們在微信上24小時期待你的聲音

解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流