我有一个类似这样的架构:
{
_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文档,我理解了他们的基本示例并与他们一起玩,但我只是很难想出如何做更复杂的例子。
答案 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")]
}]
}