zoukankan      html  css  js  c++  java
  • mongodb(回滚)

    事实上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);
            }
        });
    }
  • 相关阅读:
    19. 各种提权姿势总结
    18. 各种数据库查询基础
    Kafka——分布式消息系统
    跳表
    Linux的io机制
    Make命令
    ElasticSearch之二——集群
    ElasticSearch之一——索引
    Scribe日志收集工具
    Thrift 的原理和使用
  • 原文地址:https://www.cnblogs.com/Fredric-2013/p/4417973.html
Copyright © 2011-2022 走看看