MongoDB聚合函数,用于返回特定日期范围内的按天计数

时间:2019-02-04 12:30:34

标签: node.js mongoose aggregation-framework

我还需要获取特定日期范围内每天的个人用户数。假设一个月(1日至30日)内总共有100个用户,我需要获得类似的计数

{
    1st - 2 users
    2nd - 10 users
}

MessagesSchema.statics.totalMessagesGraph = (id, startDate, endDate, platform) => {
    return Messages.aggregate([
        {
            $match: {
                id: id,
                platform: platform,
                timestamp: {
                    $gte: new Date(startDate),
                    $lte: new Date(endDate)
                }
            }
        }    
    ])
}

在这里应该得到什么结果?

预期结果:

对于该特定日期,范围为每天的计数。

{
    date1 - 20,
    date2 - 22,
    date3 - 24,
    ...
    date30 - 12 
}

预期输出应与上面类似。 $match之后应进行什么查询。如果可能,请获取样本数据集并提供输出。

2 个答案:

答案 0 :(得分:1)

使用 $ group 获取每日计数 例如

db.collection.aggregate([
         {
            $match: {
                //id: id,
                //platform: platform,
                //timestamp: {
                    //$gte: new Date(startDate),
                    //$lte: new Date(endDate)
                //}
            //}
            // Your matching logic
          },
          /* Now grouping users based on _id or id parameter for each day 
          from the above match results.

          $createdAt can be replaced by date property present in your database. 
          */
          { $group : {
                id : { day: { $dayOfMonth: "$createdAt" },
                        month: { $month: "$createdAt" }, 
                        year: { $year: "$createdAt" } },
                        count : {$sum : 1} 
                }
           }
        ])

基于此,您将获得如下输出:

{
    "_id" : {
        "day" : 14,
        "month" : 1,
        "year" : 2017
    },
    "count" : 2.0
}

/* 2 */
{
    "_id" : {
        "day" : 31,
        "month" : 1,
        "year" : 2017
    },
    "count" : 8.0
}

/* 3 */
{
    "_id" : {
        "day" : 2,
        "month" : 1,
        "year" : 2017
    },
    "count" : 4.0
}

...

您可以使用上面的查询结果来获取所需的输出。

更精确地说,您可以从组查询中删除月份和年份参数,以获取如下输出:

/* 1 */
{
    "_id" : {
        "day" : 25
    },
    "count" : 7.0
}

/* 2 */
{
    "_id" : {
        "day" : 18
    },
    "count" : 4.0
}

/* 3 */
{
    "_id" : {
        "day" : 17
    },
    "count" : 4.0
}
...

作为参考,您可以查看mongoDB文档,也可以参考此。

MongoDB Aggregation Queries for "Counts Per Day"

希望以上示例可以帮助您获取所需的输出。

答案 1 :(得分:1)

这是我经过几次试验后得出的解决方案。

            {
                '$project': {
                    timestamp: {'$dateToString': {format: '%Y-%m-%d', date: '$timestamp'}}                }
            }, {
                '$group': {
                    _id: {timestamp: '$timestamp'},
                    count: {'$sum': 1}
                }
            }

这是输出

  "response": [
    {
      "_id": {
        "timestamp": "2019-01-08"
      },
      "count": 1
    },
    {
      "_id": {
        "timestamp": "2019-01-13"
      },
      "count": 1
    },
    {
      "_id": {
        "timestamp": "2019-01-16"
      },
      "count": 1
    },
    {
      "_id": {
        "timestamp": "2019-01-17"
      },
      "count": 1
    },
    {
      "_id": {
        "timestamp": "2019-01-19"
      },
      "count": 1
    },
    {
      "_id": {
        "timestamp": "2019-02-01"
      },
      "count": 1
    }
  ]