1樓:
首先一點,如果只是select 的話,oracle是不會加任何鎖的,也就是oracle對 select 讀到的資料不會有任何限制,雖然這時候有可能另外乙個程序正在修改表中的資料,並且修改的結果可能影響到你目前select語句的結果,但是因為沒有鎖,所以select結果為當前時刻表中記錄的狀態。
如果加入了for update, 則oracle一旦發現(符合查詢條件的)這批資料正在被修改,則不會發出該select語句查詢,直到資料被修改結束(被commit),馬上自動執行這個select語句。
同樣,如果該查詢語句發出後,有人需要修改這批資料(中的一條或幾條),它也必須等到查詢結束後(commit)後,才能修改。
for update nowait和 for update 都會對所查詢到得結果集進行加鎖,所不同的是,如果另外乙個執行緒正在修改結果集中的資料,for update nowait 不會進行資源等待,只要發現結果集中有些資料被加鎖,立刻返回 「ora-00054錯誤,內容是資源正忙, 但指定以 nowait 方式獲取資源」。
for update 和 for update nowait 加上的是乙個行級鎖,也就是只有符合where條件的資料被加鎖。如果僅僅用update語句來更改資料時,可能會因為加不上鎖而沒有響應地、莫名其妙地等待,但如果在此之前,for update nowait語句將要更改的資料試探性地加鎖,就可以通過立即返回的錯誤提示而明白其中的道理,或許這就是for update和nowait的意義之所在。
經過測試,以for update 或 for update nowait方式進行查詢加鎖,在select的結果集中,只要有任何乙個記錄在加鎖,則整個結果集都在等待系統資源(如果是nowait,則丟擲相應的異常)
2樓:匿名使用者
1.解答
for update 在select的時候對行加鎖
nowait子句的作用就是當發現請求加鎖資源已經被鎖定未釋放的時候,不等待,直接報錯返回。
2.select...for update 語句的語法
select ... for update [of column_list][wait n|nowait][skip locked];
其中:of 子句用於指定即將更新的列,即鎖定行上的特定列。
wait 子句指定等待其他使用者釋放鎖的秒數,防止無限期的等待
wait優點如下:
1防止無限期地等待被鎖定的行;
2允許應用程式中對鎖的等待時間進行更多的控制。
3對於互動式應用程式非常有用,因為這些使用者不能等待不確定
4 若使用了skip locked,則可以越過鎖定的行,不會報告由wait n 引發的『資源忙』異常報告
3.例子
在1視窗中
select * from t where a='1' for update;
在2視窗中
select * from t where a='1' for update; 則這一句sql在執行時,由於資源已經被1視窗的事務加了行鎖,則永遠處於等待狀態,除非1視窗中的事務結束(提交或回滾)。
如何才能讓sql2不等待或等待指定的時間呢? 我們再執行sql3
select * from t where a='1' for update nowait; 則在執行此sql時,直接報資源忙的異常。
若執行 select * from t where a='1' for update wait 6; 則在等待6秒後,報資源忙的異常。
如果執行 select * from t where a='1' for update nowait skip locked; 則執行sql時,即不等待,也不報資源忙異常。
3樓:乙個小鹹魚
同樣都是獲取鎖並鎖定記錄,for update遇到記錄已經被鎖定時會等待鎖的釋放(直到超時),for update nowait則馬上報ora-00054錯誤
truthfulness和truth的區別
truthfulness n.誠實 真實 u the virtues of loyalty,courage,and truthfulness.忠誠,勇敢和誠實的美德。she is satisfied of the truthfulness of my statement.她完全相信我的話的真實。tr...
belong to和belongs to的區別
belong to 和belongs to的區別為什麼有的是itmust belong to carla。而有些卻是i think it belongs 頭 jim.我來答藍天也有星空 lv.14 2018 01 01 belong to 翻譯成中文是 屬於 的意思,一般會這樣用或者翻譯。1.bel...
why do you和why are you的區別,後面跟什麼?最好是能舉出例句
球球小龍蝦 這個區別的方法可以把句子還原成一般現在時,看看句子中用不用be。比如你的問題 you are going shopping tomorrow.句中要有be動詞are,所以問句時候要用why are you you will go shopping tomorrow.句中沒有有動詞go,變...