难以绕过复杂的$ group'ing /聚合

时间:2016-10-29 21:05:12

标签: javascript mongodb mongoose mongodb-query aggregation-framework

我有一个类似这样的架构:

{
  _id: <objectid>
  customer: <objectid>
  employee: <objectid>
  date: <Month/day/year>
  amount: <Number>
}

使用angular,我正在尝试创建一个页面来提取数据并为每天构建单独的表。所以像我昨天会有一个标签,这将打开一个表格,其中列出了我所有员工的列表以及当天的总和。像这样:

[{
  date: 10/29/2019
  dataFromThisDate: [
    {
      employee: <name>
      sumAmount: <sum(amount for this date)>
      list:  [<array of all of the transaction _ids 
    },
    {
      employee: <name 2> 
      //etc
    }]
 },
 {
   date: 10/30/2019
   dataFromThisDate: //etc
 }]

基本上我已经得到的只是:

MyCollection.aggregate(
  [{
    $group: {
       _id: "$date"
    }
  }],function(err, result) { //blah }
)

但我不确定如何进行嵌套分组(首先是按日期,然后是雇员在那个日期)。只是想一想,感觉就像我必须按日期分组,然后将所有数据传递给新的分组管道?

抱歉,我没有更多我尝试过的东西,这整个聚合对我来说都是全新的,我找不到与我正在努力学习的相似的好例子。我查看了mongodb的api文档,我理解了他们的基本示例并与他们一起玩,但我只是很难想出如何做更复杂的例子。

1 个答案:

答案 0 :(得分:1)

你可以尝试这样的事情。这使用两组。第一组按日期和员工,汇总金额并添加交易ID。按日期排列第二组,并为员工添加总金额和交易清单。

aggregate([{
    $group: {
        _id: {
            date: "$date",
            employee: "$employee"
        },
        amount: {
            $sum: "$amount"
        },
        transactionIds: {
            $push: "$_id"
        }
    }
}, {
    $group: {
        _id: "$_id.date",
        dataFromThisDate: {
            $push: {
                employee: "$_id.employee",
                sumAmount: "$amount",
                list: "$transactionIds"
            }
        }
    }
}])

输出

 {
    "_id": "12/21/2016",
    "dataFromThisDate": [{
        "employee": "employee1",
        "sumAmount": 100,
        "list": [ObjectId("58151e881ac3c9ce82782663")]
    }, {
        "employee": "employee2",
        "sumAmount": 73,
        "list": [ObjectId("58151e881ac3c9ce82782665"), ObjectId("58151e881ac3c9ce82782666")]
    }]
 }