自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

淺談Oracle行級(jí)鎖的特殊用法

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

Oracle有許多的鎖,各種鎖的效用是不一樣的。下面重點(diǎn)介紹Oracle行級(jí)鎖,Oracle行級(jí)鎖只對(duì)用戶正在訪問的行進(jìn)行鎖定??梢愿玫谋WC數(shù)據(jù)的安全性。

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

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

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

  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中打開兩個(gè)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'; 這一點(diǎn)問題也沒有,因?yàn)樾屑?jí)鎖不會(huì)影響純粹的select語(yǔ)句
再運(yùn)行sql2

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

3

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

則在執(zhí)行此sql時(shí),直接報(bào)資源忙的異常。
若執(zhí)行 select * from t where a='1' for update wait 6; 則在等待6秒后,報(bào) 資源忙的異常。
如果我們執(zhí)行sql4

4.

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

d; 則執(zhí)行sql時(shí),即不等待,也不報(bào)資源忙異常。
現(xiàn)在我們看看執(zhí)行如下操作將會(huì)發(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)加行級(jí)鎖,其原理和操作與select for update并無(wú)兩樣。
select for update of,這個(gè)of子句在牽連到多個(gè)表時(shí),具有較大作用,如不使用of指定鎖定的表的列,則所有表的相關(guān)行均被鎖定,若在of中指定了需修改的列,則只有與這些列相關(guān)的表的行才會(huì)被鎖定。

【編輯推薦】

  1. 修改Oracle存儲(chǔ)過程所需代碼
  2. 對(duì)Oracle存儲(chǔ)過程的總結(jié)
  3. 實(shí)現(xiàn)Oracle存儲(chǔ)過程的實(shí)際應(yīng)用的代碼 
  4. 深入高性能的Oracle動(dòng)態(tài)SQL開發(fā) 
  5. Oracle SQL的優(yōu)化規(guī)則解析 
責(zé)任編輯:佚名 來(lái)源: my god
相關(guān)推薦

2010-05-24 12:50:59

MySQL表級(jí)鎖

2024-11-29 07:38:12

MySQL數(shù)據(jù)庫(kù)

2024-05-13 12:44:00

InnodbMySQL行級(jí)鎖

2020-02-06 10:02:45

MySQL數(shù)據(jù)庫(kù)全局鎖

2010-11-22 14:42:13

MySQL行級(jí)鎖

2022-10-24 00:33:59

MySQL全局鎖行級(jí)鎖

2010-10-15 14:10:56

Mysql行級(jí)鎖

2024-12-18 07:40:50

MySQL機(jī)制

2023-08-26 11:32:07

2010-07-13 16:20:30

SQL Server數(shù)

2010-04-26 10:09:22

Oracle存儲(chǔ)過程

2011-06-09 15:15:52

RAII

2010-10-27 15:03:47

Oracle with

2010-11-24 15:53:11

MySQL中SELEC

2009-05-04 09:52:49

Oracle優(yōu)化排序

2010-07-20 12:52:26

Perl特殊變量

2009-11-17 17:47:56

Oracle Shar

2021-01-15 05:12:14

Java并發(fā)樂觀鎖

2009-05-06 11:09:10

Oracle物化視圖數(shù)據(jù)庫(kù)

2011-03-21 13:10:01

OracleDDL鎖
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)