Oracle中的select for update 用法
通常情況下,select語句是不會對資料加鎖,不會妨礙影響其他的DML和DDL操作。藉助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一次即可釋放.