V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
kenneth
V2EX  ›  程序员

MongoDB 中如何对一个字段进行累加操作?

  •  
  •   kenneth · 2014-04-30 16:00:35 +08:00 · 7452 次点击
    这是一个创建于 3656 天前的主题,其中的信息可能已经有所发展或是发生改变。
    比如
    第一天 ¥5
    第二天 ¥5

    我要求一共赚了多少钱 10
    10 条回复    2014-05-01 10:23:59 +08:00
    turing
        1
    turing  
       2014-04-30 16:06:13 +08:00
    搜索一下 $inc 操作符
    liangdi
        2
    liangdi  
       2014-04-30 16:07:44 +08:00 via Android
    有$sum
    kenneth
        3
    kenneth  
    OP
       2014-04-30 16:11:28 +08:00
    @turing $inc是可以增加和减少,但是我们累加求和。

    @liangdi 你确定有这个操作符?
    hydrazt
        4
    hydrazt  
       2014-04-30 16:12:40 +08:00
    mapreduce
    kenneth
        5
    kenneth  
    OP
       2014-04-30 16:13:23 +08:00   ❤️ 1
    @hydrazt 能否说说大概怎么搞?
    hydrazt
        6
    hydrazt  
       2014-04-30 16:15:59 +08:00
    turing
        7
    turing  
       2014-04-30 16:21:12 +08:00
    累加求和用 mapReduce

    model.mapReduce({
    map: function() {
    emit(this.earn, 1)
    },
    reduce: function(key, values){
    return Array.sum(values);
    },
    query: {
    ... // 查询参数
    }
    });

    http://docs.mongodb.org/manual/core/map-reduce/
    kenneth
        8
    kenneth  
    OP
       2014-04-30 16:26:04 +08:00
    @turing js高手,果然对Mongodb更好理解。我再学习一下。
    wbean
        9
    wbean  
       2014-04-30 16:47:29 +08:00   ❤️ 1
    mongo中简单的统计需求不用祭出mapreduce这种大杀器。
    Aggregation就可以了。
    通过一些基础管道操作,如$project,$match,$group,$limit,$skip,$sort 和 一些 常用表达式如$sum,$avg,$min,$max 等实现基础的统计需求

    db.collection.aggregate(
    [
    $match:{}
    $group:{$_id:"",total:{$sum:"$amount"}}
    ]
    );
    benleewindy
        10
    benleewindy  
       2014-05-01 10:23:59 +08:00
    @turing Reduce本身就是对collection做迭代归并操作,肯定能满足,简单需求似乎过重。。。。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   902 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 19:05 · PVG 03:05 · LAX 12:05 · JFK 15:05
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.