內(nèi)存優(yōu)化表(Memory-Optimized Table,簡稱MOT)使用樂觀策略(optimistic approach)實現(xiàn)事務(wù)的并發(fā)控制,在讀取MOT時,使用多行版本化(Multi-Row versioning)創(chuàng)建數(shù)據(jù)快照,讀操作不會對數(shù)據(jù)加鎖,因此,讀寫操作不會相互阻塞。寫操作會申請行級鎖,如果兩個事務(wù)嘗試更新同一數(shù)據(jù)行,SQL Server檢測到寫-寫沖突,產(chǎn)生錯誤(Error 41302),將后后創(chuàng)建的事務(wù)作為失敗者,回滾事務(wù)的操作。雖然MOT事務(wù)使用無鎖結(jié)構(gòu)(Lock-Free),不會產(chǎn)生阻塞,但是,訪問MOT仍然會產(chǎn)生Wait,通常情況下,等待時間是非常短暫的。

一,MOT使用樂觀并發(fā)事務(wù)控制

1,并發(fā)控制策略

事務(wù)的并發(fā)控制策略分為樂觀策略和悲觀策略,SQL Server支持兩種并發(fā)策略。

1.1,悲觀策略(Pessimistic Approach)

悲觀策略認為每一個數(shù)據(jù)更新都潛在地存在沖突,為了避免數(shù)據(jù)爭用,事務(wù)在讀取數(shù)據(jù)時申請共享鎖,在更新數(shù)據(jù)時對數(shù)據(jù)加互斥鎖(Locking)。在沖突發(fā)生時,通過加鎖阻塞其他事務(wù);其他事務(wù)檢測到?jīng)_突后,等待擁有資源的事務(wù)釋放互斥鎖,其他事務(wù)只有獲取到資源上的加鎖,才能執(zhí)行讀寫操作。

悲觀策略主要用于數(shù)據(jù)爭用激烈,并且發(fā)生發(fā)沖突時用鎖保護數(shù)據(jù)的成本低于回滾事務(wù)的成本的環(huán)境中。

延伸閱讀

學(xué)習(xí)是年輕人改變自己的最好方式-Java培訓(xùn),做最負責(zé)任的教育,學(xué)習(xí)改變命運,軟件學(xué)習(xí),再就業(yè),大學(xué)生如何就業(yè),幫大學(xué)生找到好工作,lphotoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動軟件開發(fā)培訓(xùn),網(wǎng)站設(shè)計培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)學(xué)習(xí)是年輕人改變自己的最好方式