MongoDB
 sql >> डेटाबेस >  >> NoSQL >> MongoDB

MongoDB $sum एकत्रीकरण पाइपलाइन ऑपरेटर

MongoDB में, $sum एग्रीगेशन पाइपलाइन ऑपरेटर संख्यात्मक मानों के योग की गणना और रिटर्न करता है।

सिंटैक्स

$sum ऑपरेटर दो सिंटैक्स का समर्थन करता है।

सिंटैक्स 1:

{ $sum: <expression> }

सिंटैक्स 2:

{ $sum: [ <expression1>, <expression2> ... ]  }

पहला सिंटैक्स एक तर्क को स्वीकार करता है और दूसरा सिंटैक्स कई तर्कों को स्वीकार करता है।

जब $group . में उपयोग किया जाता है चरण, आप केवल पहले सिंटैक्स का उपयोग कर सकते हैं। इस मामले में, $sum उन सभी सांख्यिक मानों का सामूहिक योग लौटाता है, जो कुंजी द्वारा समान समूह को साझा करने वाले दस्तावेज़ों के समूह में प्रत्येक दस्तावेज़ में निर्दिष्ट अभिव्यक्ति को लागू करने के परिणामस्वरूप होते हैं।

सिंटैक्स 1 के उदाहरण (एकल तर्क)

यहां कुछ उदाहरण दिए गए हैं जो सिंटैक्स 1 का उपयोग करते हैं।

समूहीकृत दस्तावेज़

यह उदाहरण $sum . का उपयोग करता है $group . के संयोजन के साथ कुंजी द्वारा समूहीकृत दस्तावेज़ों के समूह में राशि वापस करने के लिए।

मान लीजिए हमारे पास pets . नामक संग्रह है निम्नलिखित दस्तावेजों के साथ:

{ "_id" : 1, "name" : "Wag", "type" : "Dog", "weight" : 20 }
{ "_id" : 2, "name" : "Bark", "type" : "Dog", "weight" : 10 }
{ "_id" : 3, "name" : "Meow", "type" : "Cat", "weight" : 7 }
{ "_id" : 4, "name" : "Scratch", "type" : "Cat", "weight" : 8 }
{ "_id" : 5, "name" : "Bruce", "type" : "Kangaroo", "weight" : 100 }
{ "_id" : 6, "name" : "Hop", "type" : "Kangaroo", "weight" : 130 }
{ "_id" : 7, "name" : "Punch", "type" : "Kangaroo", "weight" : 200 }
{ "_id" : 8, "name" : "Snap", "type" : "Cat", "weight" : 12 }
{ "_id" : 9, "name" : "Ruff", "type" : "Dog", "weight" : 30 }

हम इन दस्तावेज़ों को उनके type . के आधार पर समूहित कर सकते हैं फ़ील्ड, और फिर $sum . का उपयोग करें weight . का योग लौटाने के लिए प्रत्येक समूह के लिए फ़ील्ड:

db.pets.aggregate(
   [
     {
       $group:
          {
            _id: "$type",
            sum: { $sum: "$weight" }
          }
     }
   ]
)

परिणाम:

{ "_id" : "Kangaroo", "sum" : 430 }
{ "_id" : "Cat", "sum" : 27 }
{ "_id" : "Dog", "sum" : 60 }

सरणी

यह उदाहरण $sum . पर लागू होता है एक एकल दस्तावेज़ के लिए जिसमें मानों की एक सरणी वाला फ़ील्ड होता है।

यह विकल्प केवल एकल तर्क सिंटैक्स का उपयोग करते समय उपलब्ध होता है। बहु-तर्क सिंटैक्स का उपयोग करते समय सरणियों को अनदेखा कर दिया जाता है (इस पर और अधिक नीचे)।

मान लीजिए हमारे पास players . नामक संग्रह है निम्नलिखित दस्तावेजों के साथ:

{ "_id" : 1, "player" : "Homer", "scores" : [ 1, 7, 2, 3, 8, 7, 1 ] }
{ "_id" : 2, "player" : "Marge", "scores" : [ 0, 1, 8, 17, 18, 8 ] }
{ "_id" : 3, "player" : "Bart", "scores" : [ 15, 11, 8, 0, 1, 3 ] }
{ "_id" : 4, "player" : "Brian", "scores" : [ 7 ] }
{ "_id" : 5, "player" : "Farnsworth", "scores" : [ ] }
{ "_id" : 6, "player" : "Meg", "scores" : null }
{ "_id" : 7, "player" : "Ron" }

हम $sum apply लागू कर सकते हैं scores . तक प्रत्येक दस्तावेज़ में फ़ील्ड:

db.players.aggregate(
   [
     {
       $project:
          {
            player: 1,
            sum: { $sum: "$scores" }
          }
     }
   ]
)

परिणाम:

{ "_id" : 1, "player" : "Homer", "sum" : 29 }
{ "_id" : 2, "player" : "Marge", "sum" : 52 }
{ "_id" : 3, "player" : "Bart", "sum" : 38 }
{ "_id" : 4, "player" : "Brian", "sum" : 7 }
{ "_id" : 5, "player" : "Farnsworth", "sum" : 0 }
{ "_id" : 6, "player" : "Meg", "sum" : 0 }
{ "_id" : 7, "player" : "Ron", "sum" : 0 }

इस मामले में, पहले चार दस्तावेज़ों ने विभिन्न संख्याओं का योग लौटाया जो उनके संबंधित सरणियों में थे।

दस्तावेज़ 4 के मामले में, यह संख्या के समान ही था, क्योंकि सरणी में केवल एक ही संख्या थी।

दस्तावेज़ 5 लौटा 0 क्योंकि हमने एक खाली सरणी प्रदान की है।

दस्तावेज़ 6 लौटा 0 क्योंकि हमने null प्रदान किया है तर्क के रूप में।

दस्तावेज़ 7 लौटा 0 क्योंकि फ़ील्ड मौजूद ही नहीं था।

सिंटैक्स 2 का उदाहरण (एकाधिक तर्क)

दूसरे सिंटैक्स में $sum . प्रदान करना शामिल है एक से अधिक तर्क के साथ। $sum फिर दिए गए सभी तर्कों के आधार पर योग की गणना करता है।

मान लीजिए हमारे पास data . नामक संग्रह है निम्नलिखित दस्तावेजों के साथ:

{ "_id" : 1, "a" : 1, "b" : 2, "c" : 3, "d" : 4 }
{ "_id" : 2, "a" : 1, "b" : 2, "c" : 3, "d" : [ 4 ] }
{ "_id" : 3, "a" : 1, "b" : 2, "c" : 3, "d" : "Hey" }
{ "_id" : 4, "a" : "One", "b" : "Two", "c" : "Three", "d" : "Four" }

हम $sum . का उपयोग कर सकते हैं a . का योग लौटाने के लिए , b , c , और d प्रत्येक दस्तावेज़ के क्षेत्र:

db.data.aggregate(
   [
     {
       $project:
          {
            sum: { $sum: [ "$a", "$b", "$c", "$d" ] }
          }
     }
   ]
)

परिणाम:

{ "_id" : 1, "sum" : 10 }
{ "_id" : 2, "sum" : 6 }
{ "_id" : 3, "sum" : 6 }
{ "_id" : 4, "sum" : 0 }

दस्तावेज़ 1 1 . के इनपुट मानों का योग देता है , 2 , 3 , और 4

हालांकि, अगले दो दस्तावेज़ों ने केवल 1 . के इनपुट मानों का योग लौटाया , 2 , और 3 . $sum ऑपरेटर ने उनके d . पर ध्यान नहीं दिया खेत।

ऐसा इसलिए है क्योंकि $sum गैर-संख्यात्मक मानों को अनदेखा करता है। तो इस मामले में यह नजरअंदाज कर दिया "Hey" दस्तावेज़ 3 में और शेष (संख्यात्मक) फ़ील्ड से योग की गणना की।

दस्तावेज़ 2 के लिए, इसका d फ़ील्ड में एक सरणी है। जैसा कि बताया गया है, $sum बहु-तर्क सिंटैक्स का उपयोग करते समय ऑपरेटर सरणियों को अनदेखा करता है। अधिक सटीक रूप से, यह इस संदर्भ में उपयोग किए जाने पर सरणियों को गैर-संख्यात्मक मानों के रूप में मानता है, और $sum गैर-संख्यात्मक मानों की उपेक्षा करता है।

यदि सभी मान गैर-संख्यात्मक हैं, तो $sum रिटर्न 0 . हम इसे दस्तावेज़ 4 के साथ देख सकते हैं।

अनुपलब्ध फ़ील्ड

बहु-तर्क सिंटैक्स का उपयोग करते समय, $sum किसी भी लापता फ़ील्ड को अनदेखा करता है। यही है, यदि आप किसी ऐसे क्षेत्र की आपूर्ति करते हैं जो मौजूद नहीं है, तो वह इसे अनदेखा कर देता है। यदि कोई भी फ़ील्ड मौजूद नहीं है, तो यह 0 लौटाता है ।

उदाहरण:

db.data.aggregate(
   [
     {
       $project:
          {
            sum: { $sum: [ "$a", "$b", "$c", "$d", "$e" ] }
          }
     }
   ]
)

परिणाम:

{ "_id" : 1, "sum" : 10 }
{ "_id" : 2, "sum" : 6 }
{ "_id" : 3, "sum" : 6 }
{ "_id" : 4, "sum" : 0 }

इस मामले में मैंने एक अतिरिक्त क्षेत्र प्रदान किया ($e ) जो दस्तावेजों में मौजूद नहीं है। $sum शेष फ़ील्ड के आधार पर योग की गणना की जो करते हैं मौजूद है।

हालांकि, यहां क्या होता है जब कोई नहीं फ़ील्ड मौजूद हैं:

db.data.aggregate(
   [
     {
       $project:
          {
            result: { $sum: [ "$x", "$y", "$z" ] }
          }
     }
   ]
)

परिणाम:

{ "_id" : 1, "result" : 0 }
{ "_id" : 2, "result" : 0 }
{ "_id" : 3, "result" : 0 }
{ "_id" : 4, "result" : 0 }

परिणाम 0 . है सभी दस्तावेजों के लिए।

जैसा कि हमने पहले देखा, एकल-तर्क सिंटैक्स का उपयोग करते समय, एक अनुपलब्ध फ़ील्ड का परिणाम 0 . होता है ।

उदाहरण:

db.pets.aggregate(
   [
     {
       $group:
          {
            _id: "$type",
            sum: { $sum: "$oops!" }
          }
     }
   ]
)

परिणाम:

{ "_id" : "Cat", "sum" : 0 }
{ "_id" : "Dog", "sum" : 0 }
{ "_id" : "Kangaroo", "sum" : 0 }

उपलब्ध चरण

$sum निम्नलिखित चरणों में उपलब्ध है:

  • $group
  • $project
  • $addFields
  • $set
  • $replaceRoot
  • $replaceWith
  • $match चरण जिसमें एक $expr . शामिल है अभिव्यक्ति

  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. लिनक्स पर जर्नल फाइलों के लिए एरर मोंगॉड डेड लेकिन सबसिस लॉक और अपर्याप्त खाली जगह क्यों मिल रही है?

  2. Mongoimport के साथ MongoDB में JSON फ़ाइल आयात करें

  3. mongod --bind_ip docker-compose संस्करण 2 का उपयोग कर रहा है

  4. MongoDB - किसी सरणी के अंतिम तत्व पर क्वेरी?

  5. मैक पर मोंगोडीबी स्थापित करें