MongoDB - एकत्रीकरण

एकत्रीकरण संचालन डेटा रिकॉर्ड की प्रक्रिया करता है और गणना किए गए परिणाम लौटाता है। एक साथ कई दस्तावेजों से एकत्रीकरण संचालन समूह मूल्य, और एकल परिणाम वापस करने के लिए समूहीकृत डेटा पर कई प्रकार के संचालन कर सकते हैं। SQL काउंट (*) में और समूह के अनुसार MongoDB एकत्रीकरण के बराबर है।

कुल () विधि

MongoDB में एकत्रीकरण के लिए, आपको उपयोग करना चाहिए aggregate() तरीका।

वाक्य - विन्यास

का मूल सिंटैक्स aggregate() विधि इस प्रकार है -

>db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION)

उदाहरण

संग्रह में आपके पास निम्नलिखित डेटा हैं -

{
   _id: ObjectId(7df78ad8902c)
   title: 'MongoDB Overview', 
   description: 'MongoDB is no sql database',
   by_user: 'tutorials point',
   url: 'http://www.tutorialspoint.com',
   tags: ['mongodb', 'database', 'NoSQL'],
   likes: 100
},
{
   _id: ObjectId(7df78ad8902d)
   title: 'NoSQL Overview', 
   description: 'No sql database is very fast',
   by_user: 'tutorials point',
   url: 'http://www.tutorialspoint.com',
   tags: ['mongodb', 'database', 'NoSQL'],
   likes: 10
},
{
   _id: ObjectId(7df78ad8902e)
   title: 'Neo4j Overview', 
   description: 'Neo4j is no sql database',
   by_user: 'Neo4j',
   url: 'http://www.neo4j.com',
   tags: ['neo4j', 'database', 'NoSQL'],
   likes: 750
},

अब उपरोक्त संग्रह से, यदि आप एक सूची दिखाना चाहते हैं कि प्रत्येक उपयोगकर्ता द्वारा कितने ट्यूटोरियल लिखे गए हैं, तो आप निम्नलिखित का उपयोग करेंगे aggregate() विधि -

> db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$sum : 1}}}])
{ "_id" : "tutorials point", "num_tutorial" : 2 }
{ "_id" : "Neo4j", "num_tutorial" : 1 }
>

उपरोक्त उपयोग के मामले के लिए Sql समकक्ष क्वेरी होगी select by_user, count(*) from mycol group by by_user

उपरोक्त उदाहरण में, हमने फ़ील्ड द्वारा दस्तावेज़ों को समूहीकृत किया है by_userऔर उपयोगकर्ता की प्रत्येक घटना पर पिछले मूल्य का योग बढ़ जाता है। निम्नलिखित एकत्रीकरण अभिव्यक्तियों की एक सूची है।

अभिव्यक्ति विवरण उदाहरण
$ योग संग्रह में सभी दस्तावेजों से परिभाषित मूल्य तय करता है। db.mycol.aggregate ([{$ group: {_id: "$ by_user", num_tutorial: {$ sum: "$ likes"}}}])
$ औसत संग्रह में सभी दस्तावेजों से दिए गए सभी मूल्यों के औसत की गणना करता है। db.mycol.aggregate ([{$ group: {_id: "$ by_user", num_tutorial: {$ avg: "$ likes"}}}]]
$ मिनट संग्रह में सभी दस्तावेजों से संबंधित मूल्यों के न्यूनतम हो जाता है। db.mycol.aggregate ([{$ group: {_id: "$ by_user", num_tutorial: {$ min: "$ likes"}}}])
$ अधिकतम संग्रह में सभी दस्तावेजों से संबंधित मूल्यों का अधिकतम हो जाता है। db.mycol.aggregate ([{$ group: {_id: "$ by_user", num_tutorial: {$ max: "$ likes"}}}]]
$ धक्का परिणामी दस्तावेज़ में किसी सरणी में मान सम्मिलित करता है। db.mycol.aggregate ([{$ group: {_id: "$ by_user", url: {$ पुश: "$ url"}}}])
$ addToSet परिणामी दस्तावेज़ में किसी सरणी में मान सम्मिलित करता है लेकिन डुप्लिकेट नहीं बनाता है। db.mycol.aggregate ([{$ group: {_id: "$ by_user", url: {$ addToSet: "$ url"}}}])
पहले $ समूहीकरण के अनुसार स्रोत दस्तावेज़ से पहला दस्तावेज़ प्राप्त करता है। आमतौर पर यह केवल पहले से लागू "$ सॉर्ट" -स्टेज के साथ मिलकर समझ में आता है। db.mycol.aggregate ([{$ group: {_id: "$ by_user", first_url: {$ first: "$ url"}}}])
$ पिछले समूहीकरण के अनुसार स्रोत दस्तावेज़ से अंतिम दस्तावेज़ प्राप्त करता है। आमतौर पर यह केवल पहले से लागू "$ सॉर्ट" -स्टेज के साथ मिलकर समझ में आता है। db.mycol.aggregate ([{$ group: {_id: "$ by_user", last_url: {$ last: "$ url"}}}])

पाइपलाइन की अवधारणा

UNIX कमांड में, शेल पाइपलाइन का मतलब कुछ इनपुट पर एक ऑपरेशन को निष्पादित करने और अगले कमांड के लिए इनपुट के रूप में आउटपुट का उपयोग करने की संभावना है। MongoDB भी एकत्रीकरण ढांचे में इसी अवधारणा का समर्थन करता है। संभावित चरणों का एक सेट है और उनमें से प्रत्येक को एक इनपुट के रूप में दस्तावेजों के एक सेट के रूप में लिया जाता है और परिणामी दस्तावेजों (या पाइप लाइन के अंत में अंतिम परिणामी JSON दस्तावेज़) के परिणामस्वरूप उत्पन्न होता है। यह तब बारी में अगले चरण और इतने पर के लिए इस्तेमाल किया जा सकता है।

एकत्रीकरण ढांचे में संभावित चरण निम्नलिखित हैं -

  • $project - एक संग्रह से कुछ विशिष्ट क्षेत्रों का चयन करने के लिए उपयोग किया जाता है।

  • $match - यह एक फ़िल्टरिंग ऑपरेशन है और इस प्रकार यह उन दस्तावेजों की मात्रा को कम कर सकता है जिन्हें अगले चरण में इनपुट के रूप में दिया गया है।

  • $group - यह वास्तविक एकत्रीकरण करता है जैसा कि ऊपर चर्चा की गई है।

  • $sort - दस्तावेज़ों को सॉर्ट करता है।

  • $skip - इसके साथ, दस्तावेजों की दी गई राशि के लिए दस्तावेजों की सूची में आगे छोड़ना संभव है।

  • $limit - यह मौजूदा पदों से शुरू की गई संख्या द्वारा दस्तावेजों को देखने की मात्रा को सीमित करता है।

  • $unwind- इसका उपयोग दस्तावेज़ों को खोलने के लिए किया जाता है जो सरणियों का उपयोग कर रहे हैं। किसी सरणी का उपयोग करते समय, डेटा पूर्व-प्रकार की तरह होता है और इस ऑपरेशन को फिर से व्यक्तिगत दस्तावेजों के साथ पूर्ववत किया जाएगा। इस प्रकार इस चरण के साथ हम अगले चरण के लिए दस्तावेजों की मात्रा में वृद्धि करेंगे।