योग करने के लिए, $sum का उपयोग करें और विशिष्ट दस्तावेज़ों का योग प्राप्त करने के लिए, आपको MongoDB में $group का उपयोग करके उन्हें समूहित करना होगा।
आइए पहले दस्तावेजों के साथ एक संग्रह बनाएं -
>db.calculateSumOfDocument.insertOne({"ListOfUsers":["Carol","Bob"],"UsersDetails":[{"FirstUser":"Carol","TotalLikes":20},{"FirstUser":"Bob","TotalLikes":45}]}); { "acknowledged" : true, "insertedId" : ObjectId("5e084e9125ddae1f53b6220c") } >db.calculateSumOfDocument.insertOne({"ListOfUsers":["Carol","Bob"],"UsersDetails":[{"FirstUser":"Carol","TotalLikes":60},{"FirstUser":"Bob","TotalLikes":50}]}); { "acknowledged" : true, "insertedId" : ObjectId("5e084f6125ddae1f53b6220d") }
खोज () विधि की मदद से संग्रह से सभी दस्तावेजों को प्रदर्शित करने के लिए क्वेरी निम्नलिखित है -
> db.calculateSumOfDocument.find().pretty();
यह निम्नलिखित आउटपुट उत्पन्न करेगा -
{ "_id" : ObjectId("5e084e9125ddae1f53b6220c"), "ListOfUsers" : [ "Carol", "Bob" ], "UsersDetails" : [ { "FirstUser" : "Carol", "TotalLikes" : 20 }, { "FirstUser" : "Bob", "TotalLikes" : 45 } ] } { "_id" : ObjectId("5e084f6125ddae1f53b6220d"), "ListOfUsers" : [ "Carol", "Bob" ], "UsersDetails" : [ { "FirstUser" : "Carol", "TotalLikes" : 60 }, { "FirstUser" : "Bob", "TotalLikes" : 50 } ] }
एकत्रीकरण का उपयोग करके विशिष्ट दस्तावेज़ों के योग की गणना करने के लिए क्वेरी निम्नलिखित है -
> db.calculateSumOfDocument.aggregate([ ... { ... "$match": { "UsersDetails.FirstUser": "Carol" } ... }, ... { "$unwind" : "$UsersDetails" }, ... { ... "$match": { "UsersDetails.FirstUser": "Carol" } ... }, ... { ... "$group": { ... "_id": null, ... "total": { "$sum": "$UsersDetails.TotalLikes" } ... } ... } ... ]);
यह निम्नलिखित आउटपुट उत्पन्न करेगा -
{ "_id" : null, "total" : 80 }