Oracle行級鎖的特殊用法簡析

來源:互聯網
上載者:User

Oracle有許多的鎖,各種鎖的效用是不一樣的。下面重點介紹Oracle行級鎖,Oracle行級鎖只對使用者正在訪問的行進行鎖定。可以更好的保證資料的安全性。
如果該使用者正在修改某行,那麼其他使用者就可以更新同一表中該行之外的資料。
Oracle行級鎖是一種獨佔鎖定,防止其他事務修改此行,但是不會阻止讀取此行的操作。
在使用INSERT、UPDATE、DELETE 和SELECT…FOR UPDATE 等 語句時,Oracle會自動應用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 Locke d;

則執行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中指定了需修改的列,則只有與這些列相關的表的行才會被鎖定。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.