新聞中心
本文實(shí)例講述了MongoDB數(shù)據(jù)庫兩階段提交實(shí)現(xiàn)事務(wù)的方法。分享給大家供大家參考,具體如下:
MongoDB數(shù)據(jù)庫中操作單個(gè)文檔總是原子性的,然而,涉及多個(gè)文檔的操作,通常被作為一個(gè)“事務(wù)”,而不是原子性的。因?yàn)槲臋n可以是相當(dāng)復(fù)雜并且包含多個(gè)嵌套文檔,單文檔的原子性對(duì)許多實(shí)際用例提供了支持。盡管單文檔操作是原子性的,在某些情況下,需要多文檔事務(wù)。在這些情況下,使用兩階段提交,提供這些類型的多文檔更新支持。因?yàn)槲臋n可以表示為Pending數(shù)據(jù)和狀態(tài),可以使用一個(gè)兩階段提交確保數(shù)據(jù)是一致的,在一個(gè)錯(cuò)誤的情況下,事務(wù)前的狀態(tài)是可恢復(fù)的。
事務(wù)最常見的例子是以可靠的方式從A賬戶轉(zhuǎn)賬到B賬戶,在關(guān)系型數(shù)據(jù)庫中,此操作將從A賬戶減掉金額和給B賬戶增加金額的操作封裝在單個(gè)原子事務(wù)中。在MongoDB中,可以使用兩階段提交達(dá)到相同的效果。本文中的所有示例使用mongo shell與數(shù)據(jù)庫進(jìn)行交互,并假設(shè)有兩個(gè)集合:首先,一個(gè)名為accounts的集合存儲(chǔ)每個(gè)賬戶的文檔數(shù)據(jù),另一個(gè)名為transactions的集合存儲(chǔ)事務(wù)本身。
首先創(chuàng)建兩個(gè)名為A和B的賬戶,使用下面的命令:
db.accounts.save({name: "A", balance: 1000, pendingTransactions: []}) db.accounts.save({name: "B", balance: 1000, pendingTransactions: []})
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
網(wǎng)站欄目:MongoDB數(shù)據(jù)庫兩階段提交實(shí)現(xiàn)事務(wù)的方法詳解-創(chuàng)新互聯(lián)
路徑分享:http://fisionsoft.com.cn/article/dhpdgs.html