कुल योग की गणना करने के लिए और एक सबसेट लौटाएं, आपको ग्रुपिंग लागू करने और उसी डेटासेट पर स्किप/लिमिट करने की आवश्यकता है। उसके लिए आप पहलुओं का उपयोग कर सकते हैं
उदाहरण के लिए तीसरा पृष्ठ दिखाने के लिए, प्रति पृष्ठ 10 दस्तावेज़:
db.Order.aggregate([
{ '$match' : { "company_id" : ObjectId("54c0...") } },
{ '$sort' : { 'order_number' : -1 } },
{ '$facet' : {
metadata: [ { $count: "total" }, { $addFields: { page: NumberInt(3) } } ],
data: [ { $skip: 20 }, { $limit: 10 } ] // add projection here wish you re-shape the docs
} }
] )
यह 2 फ़ील्ड के साथ एक दस्तावेज़ लौटाएगा:
{
"metadata" : [
{
"total" : 300,
"page" : 3
}
],
"data" : [
{
... original document ...
},
{
... another document ...
},
{
... etc up to 10 docs ...
}
]
}