首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >MongoDB选择计数分组依据

MongoDB选择计数分组依据
EN

Stack Overflow用户
提问于 2014-04-17 01:34:53
回答 7查看 308.5K关注 0票数 250

我正在尝试使用MongoDB,试图弄清楚如何做一个简单的

代码语言:javascript
复制
SELECT province, COUNT(*) FROM contest GROUP BY province

但是我似乎不能使用聚合函数来解决这个问题。我可以使用一些非常奇怪的组语法来实现

代码语言:javascript
复制
db.user.group({
    "key": {
        "province": true
    },
    "initial": {
        "count": 0
    },
    "reduce": function(obj, prev) {
        if (true != null) if (true instanceof Array) prev.count += true.length;
        else prev.count++;
    }
});

但是有没有一种使用聚合函数的更简单/更快的方法呢?

EN

回答 7

Stack Overflow用户

回答已采纳

发布于 2014-04-17 01:39:11

这将是使用aggregate更简单的方法

代码语言:javascript
复制
db.contest.aggregate([
    {"$group" : {_id:"$province", count:{$sum:1}}}
])
票数 422
EN

Stack Overflow用户

发布于 2015-07-02 23:58:47

如果需要多个列作为分组依据,请遵循此模型。在这里,我通过statustype进行计数

代码语言:javascript
复制
  db.BusinessProcess.aggregate({
    "$group": {
        _id: {
            status: "$status",
            type: "$type"
        },
        count: {
            $sum: 1
        }
    }
   })
票数 57
EN

Stack Overflow用户

发布于 2018-01-12 01:09:05

此外,如果需要限制分组,可以使用:

代码语言:javascript
复制
db.events.aggregate( 
    {$match: {province: "ON"}},
    {$group: {_id: "$date", number: {$sum: 1}}}  
)
票数 18
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23116330

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档