Oracle中的select for update

通常情況下,select語句是不會對數據加鎖,不會妨礙影響其他的DMLDDL操作。藉助for update子句,我們可以在應用程序的層面手工實現數據加鎖保護操作。當只允許一個session進行update的時候, for update十分有用.

select…for update之後,可以使用of子句選擇對select的特定數據表進行加鎖操作。默認情況下,不使用of子句表示在select所有的數據表中加鎖。

 

select * from test for update; 會對table test進行加鎖. 此時只允許當前的session對已經存在的數據進行更新. 但其它session仍可以進行insert的操作.

 

select * from Table1 a join Table2 b on a.pkid=b.pkid where a.pkid = 10 for update of a.pkid 只鎖定Table1中滿足條件的行, 這就是使用of子句的作用. 比較常用於多個表的操作.

 

 

加入for update之後,Oracle就要求啓動一個新事務,嘗試對數據進行加鎖。如果當前已經被加鎖,默認的行爲必然是block等待。使用nowait子句的作用就是避免進行等待,當發現請求加鎖資源被鎖定未釋放的時候,直接報錯返回。如果不使用nowait或wait子句, 新的加鎖請求會一直hang住, 直到原來的commit或rollback.

 

 

select * from test where a=2 for update nowait;
ERROR at line 1:
ORA-00054: resource busy and acquire with NOWAIT specified or timeout expired

 

或者
select * from test where a=2 for update wait 3; 如果3秒內還是無法加鎖則返回錯誤.

 

 

在一個session內可以多次進行select XX for update,然後只需要commit或rollback一次即可釋放.

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章