鍍金池/ 問(wèn)答/Java  數(shù)據(jù)庫(kù)  HTML/ mongodb4.0 事務(wù)回滾問(wèn)題

mongodb4.0 事務(wù)回滾問(wèn)題

跟著網(wǎng)上的例子寫無(wú)法回滾?

db.col.find()
{ "_id" : ObjectId("5b845237d63ff6fb1220861c"), "name" : "ccy" }
{ "_id" : ObjectId("5b8453f5cf6edbf8ffc60a95"), "name" : "ssy" }
{ "_id" : ObjectId("5b8456dcf580719bba707dc1"), "name" : "ccc" }

s = db.getMongo().startSession()
session { "id" : UUID("33f4e714-a59d-4e83-8750-011bb0b9d637") }
s.startTransaction()
db.col.insert({name: 'mongo'})
WriteResult({ "nInserted" : 1 })
s.abortTransaction()
db.col.find()
{ "_id" : ObjectId("5b845237d63ff6fb1220861c"), "name" : "ccy" }
{ "_id" : ObjectId("5b8453f5cf6edbf8ffc60a95"), "name" : "ssy" }
{ "_id" : ObjectId("5b8456dcf580719bba707dc1"), "name" : "ccc" }
{ "_id" : ObjectId("5b8458e726a5a62d9970c900"), "name" : "mongo" }

如圖那樣, 開(kāi)啟了一個(gè)事務(wù), 插入了一天數(shù)據(jù), 后回滾事務(wù)。 但是數(shù)據(jù)還是插入進(jìn)去了?
請(qǐng)教大神這是為什么

回答
編輯回答
厭遇

可能你看的例子寫得就不正確。
從設(shè)計(jì)的角度講你的sessiondb.col集合沒(méi)有任何關(guān)聯(lián),系統(tǒng)怎么會(huì)知道這個(gè)session怎么會(huì)作用于這個(gè)集合上呢?真實(shí)環(huán)境中會(huì)有多個(gè)session,多個(gè)集合,系統(tǒng)必須有一定的方法來(lái)知道對(duì)應(yīng)關(guān)系,所以現(xiàn)在的寫法肯定是欠妥的。正確的寫法是:

s = db.getMongo().startSession();
s.startTransaction();
s.getDatabase("<database>").col.insert({name: 'mongo'});
s.abortTransaction();
db.col.find();

事實(shí)上在你commit之前都不應(yīng)該在集合中查詢到新插入記錄。所以之前的寫法這點(diǎn)就已經(jīng)不吻合了。
更多實(shí)例參考MongoDB官方文檔:Session.startTransaction

2017年12月3日 23:58