आप नीचे के रूप में एकत्र कर सकते हैं:
-
$group
store
. द्वारा फ़ील्ड,subtotal
की गणना करें । -
$project
एक फ़ील्डdoc
subtotal
रखने के लिए व्यवहार में समूह, अगले समूह के दौरान। -
$group
द्वाराnull
और कुल योग जमा करें।
कोड:
db.invoices.aggregate([{
$group: {
"_id": "$store",
"subtotal": {
$sum: "$total"
}
}
}, {
$project: {
"doc": {
"_id": "$_id",
"total": "$subtotal"
}
}
}, {
$group: {
"_id": null,
"total": {
$sum: "$doc.total"
},
"result": {
$push: "$doc"
}
}
}, {
$project: {
"result": 1,
"_id": 0,
"total": 1
}
}
])
आउटपुट:
{
"total": 1000,
"result": [{
"_id": "ABC",
"total": 700
}, {
"_id": "XYZ",
"total": 300
}
]
}