Я пытаюсь написать запрос вложенной группы из следующих данных:
[
{
"mmyy": "JAN-2019",
"location": "Boston",
"category": "Shoes",
"qty": 5
},
{
"mmyy": "JAN-2019",
"location": "New York",
"category": "Shoes",
"qty": 10
},
{
"mmyy": "JAN-2019",
"location": "Boston",
"category": "Hats",
"qty": 2
},
{
"mmyy": "JAN-2019",
"location": "New York",
"category": "Hats",
"qty": 3
},
{
"mmyy": "FEB-2019",
"location": "Boston",
"category": "Shoes",
"qty": 5
},
{
"mmyy": "FEB-2019",
"location": "New York",
"category": "Hats",
"qty": 10
},
]
Требуемый результат:
[
{
month: "JAN-2019",
month_total: 20,
locations:[
{
name: "Boston",
location_total: 7,
categories: [
{name: "Shoes", total: 5},
{name: "Hats", total: 2},
]
}
...
]
},
...
]
Я могу получить агрегацию второго уровня (для Месяца и Местоположения), но с трудом переводит все агрегации в категорию во вложенном результате. Это то, что я сделал, используя несколько $group
и $push
:
db.sales.aggregate([
{$group: {
_id:{ month: "$mmyy", location: "$location"},
total: { $sum: "$qty"}
}},
{ $group:{
_id: "$_id.month",
monthly_total: { $sum: "$total" },
locations: {
$push:{
name: "$_id.location",
total: "$total"
}
}
}}
])