首页 > 解决方案 > 用于返回特定日期范围的按日计数的 MongoDB 聚合函数

问题描述

我需要每天获取特定日期范围内的个人用户数量。假设一个月内(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。如果可能,请获取样本数据集并提供输出。

标签: node.jsmongooseaggregation-framework

解决方案


例如,使用$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 聚合查询

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


推荐阅读