關於oracle的行級鎖
在oracle中,行級鎖只對使用者正在訪問的行進行鎖定。
如果該使用者正在修改某行,那麼其他使用者就可以更新同一表中該行之外的資料。
行級鎖是一種排他鎖,防止其他事務修改此行,但是不會阻止讀取此行的操作。
在使用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”子句的優點如下:
⒈防止無限期地等待被鎖定的行;
⒉允許應用程式中對鎖的等待時間進行更多的控制。
⒊對於互動式應用程式非常有用,因為這些使用者不能等待不確定
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中指定了需修改的列,則只有與這些列相關的表的行才會被鎖定。[@more@]
如果該使用者正在修改某行,那麼其他使用者就可以更新同一表中該行之外的資料。
行級鎖是一種排他鎖,防止其他事務修改此行,但是不會阻止讀取此行的操作。
在使用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”子句的優點如下:
⒈防止無限期地等待被鎖定的行;
⒉允許應用程式中對鎖的等待時間進行更多的控制。
⒊對於互動式應用程式非常有用,因為這些使用者不能等待不確定
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中指定了需修改的列,則只有與這些列相關的表的行才會被鎖定。[@more@]
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/15247/viewspace-965545/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle的TX鎖(行級鎖、事務鎖)Oracle
- 關於ORACLE鎖的總結Oracle
- 關於oracle死鎖的模擬Oracle
- 關於ORACLE的鎖表與解鎖總結Oracle
- oracle鎖級別相關測試Oracle
- 關於Oracle死鎖處理方法Oracle
- 一次oracle行級鎖導致的問題Oracle
- 關於 鎖的四種狀態與鎖升級過程 圖文詳解
- 關於鎖的快速定位
- 由Oracle觸發器死鎖及行級鎖限制所衍生的解決方案Oracle觸發器
- 執行緒和鎖,鎖升級執行緒
- 關於enq: TX - row lock contention行鎖的總結ENQ
- ORACLE表和行的鎖Oracle
- 你真的會用mysql行級鎖嗎?mysql 行級鎖全解析MySql
- MySQL 行級鎖之 間隙鎖、臨鍵鎖MySql
- MySQL 行級鎖的使用以及死鎖的預防MySql
- 關於C#多執行緒、易失域、鎖的分享C#執行緒
- 併發程式設計之——讀鎖原始碼分析(解釋關於鎖降級的爭議)程式設計原始碼
- MySQL行級鎖測試MySql
- 關於 TX 鎖的兩句sqlSQL
- mysql鎖之三種行級鎖介紹MySql
- MySQL 行級鎖的特點、分類MySql
- MySQL 避免行鎖升級為表鎖——使用高效的索引MySql索引
- PostgreSQL 併發控制機制(2):表級鎖和行級鎖SQL
- MySQL複習筆記(05):MySQL表級鎖和行級鎖MySql筆記
- ORACLE關於執行計劃的簡要分析Oracle
- java 中的鎖 -- 偏向鎖、輕量級鎖、自旋鎖、重量級鎖Java
- 關於synchronized,“鎖住了誰”synchronized
- Python提高:關於GIL(全域性直譯器鎖)與執行緒互斥鎖的理解Python執行緒
- 關於資料庫鎖的總結資料庫
- Oracle資料庫關於SQL的執行計劃Oracle資料庫SQL
- 關於樂觀鎖與悲觀鎖的實際應用
- 關於觸發器在行級和語句級的執行順序問題觸發器
- 檢視oracle鎖相關資訊Oracle
- mysql 行級鎖(按照粒度分類)MySql
- MySql關於鎖的一些總結MySql
- 關於rac中的鎖簡單學習
- oracle的鎖和並行機制薦Oracle並行