顾美玲勾引管家|日韩黄色成人|国产精品theporn动漫|欧美日日日|国产精品探花在线

專業只做數據庫實訓和認證的品牌機構

微信公眾號新浪微博
免費咨詢電話:400-0909-964
當前位置: 網站首頁 > DBA實戰 > DBA課程 > oracle for update 和 for update nowait 的區別

oracle for update 和 for update nowait 的區別

文章來源: 更新時間:2020/3/16 21:19:22

在線老師點擊咨詢:

最新學訊:近期OCP認證正在報名中,因考試人員較多請盡快報名獲取最近考試時間,報名費用請聯系在線老師,甲骨文官方認證,報名從速!

我要咨詢

for update 和 for update nowait 的區別

如果在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語句有where條件時,只會鎖住對應的where條件下的數據,而不會鎖住整張表中的所有數據。

在編寫程序中,如果涉及到對表進行update,一定要對該表進行鎖定,否則將出現死鎖情況。

example:

當執行如下語句未進行commit時:SELECT * FROM cux_test t WHERE t.process_status = 'PENDING' FOR UPDATE NOWAIT;

同時再執行對應的如下程序,會報資源正忙的錯誤.

這里需要注意的是for update和for update nowait語句在同一session中只要使用一次就能鎖住對應表的對應記錄直到該session結束,意思是在一個session中如果對一張表update多次時只要進行一次lock的檢查。

本文地址:http://www.mudan321.com/dba/kecheng/24061436427.html 轉載請注明!


PostgreSQL入門到精通 100+ 個學習資料

Oracle培訓機構

金牌講師<>

冉乃綱-老師CUUG金牌講師
冉老師 CUUG金牌講師 Oracle及RedHat高級講師、Unix/Linux 資深專家...[詳細了解老師]

免費咨詢上課流程 客服在線中

陳衛星-老師CUUG金牌講師
陳老師 CUUG金牌講師 精通Oracle管理、備份恢復、性能優化 11年Ora...[詳細了解老師]

免費咨詢上課流程 客服在線中

選學校如何選擇適合自己的學校

CUUG -CHINA UNIX USER GROUP,是國際UNIX組織UNIFORUM的中國代表,是國內悠久的專業UNIX培訓機構,被譽為中國UNIX 的搖籃。多年來,以提高教學質量為本,強調素質教育,積極引進、消化國外的新技術,有效的結合中國....[詳情]

一站式服務(從入學到就業一幫到底)

入學

學習

就業

實操

食宿
地址:北京市海淀區田村山南路35號院17號樓
課程咨詢: 400-0909-964
企業服務:137 1818 8639(陳經理)
部分信息來源于網絡,如有錯誤請聯系指正!
版權所有@北京神腦資訊技術有限公司 (CUUG,中國UNIX用戶協會) Copyright 2016 ALL Rights Reserved 京ICP備11008061號-1