事实上mongodb是不支持事务的,个人理解原因如下:1.避免大量对document加锁,从而影响性能,2.非关系型的数据库,从设计上就应能尽可能的比较关联复杂的多document,一个数据应能记录在一个json document中。
然后实际的业务操作中,跨document的业务操作还是不可避免的,本文中给出node下的一种业务层替代方式(利用其同步模块及回调的结果),如下:
exports.test04 = function(enterIndex, callback) { //rollback function
function rollback(args, cb) {
if (args) {
console.log(args);
}
cb(null);
} async.series([
function(cb) {
cb(null, 'a');
},
function(cb) {
cb(null, 'b');
},
function(cb) {
cb('failed', null);
}
], function(err, results) {
if (err) { async.each(results, rollback, function(err) {
return callback(err);
});
} else {
return callback(null);
}
});
}