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

मोंगोडीबी $cond

MongoDB में, $cond एग्रीगेशन पाइपलाइन ऑपरेटर एक बूलियन एक्सप्रेशन का मूल्यांकन करता है, और दो निर्दिष्ट रिटर्न एक्सप्रेशन में से एक देता है, जो इस पर निर्भर करता है कि बूलियन एक्सप्रेशन true है या नहीं या false

$cond ऑपरेटर दो सिंटैक्स स्वीकार करता है:एक लॉन्गहैंड सिंटैक्स और एक शॉर्टहैंड सिंटैक्स। प्रत्येक के उदाहरण नीचे हैं।

उदाहरण

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

{
	"_id" : 1,
	"name" : "Fetch",
	"type" : "Dog",
	"weight" : 20,
	"height" : 30
}

लॉन्गहैंड सिंटैक्स

यहां $cond applying लागू करने का एक उदाहरण दिया गया है लॉन्गहैंड सिंटैक्स का उपयोग करके उस दस्तावेज़ में:

db.pets.aggregate(
  [
    { $project: { 
        _id: 0,
        isCanine: { 
          $cond: { if: { "$type": "Dog" }, then: "Yes", else: "No" }
          }
      }
    }
  ]
)

परिणाम:

{ "isCanine" : "Yes" }

इस उदाहरण में, हमने type . की तुलना की है एक शाब्दिक मूल्य के लिए क्षेत्र।

निम्नलिखित उदाहरण में, हम दस्तावेज़ के भीतर दो क्षेत्रों की तुलना करते हैं।

db.pets.aggregate(
  [
    { $project: { 
        _id: 0,
        bodyType: { 
          $cond: { 
            if: { 
              $gte: [ "$weight", "$height" ] }, 
              then: "Fat", 
              else: "Skinny" 
              }
          }
      }
    }
  ]
)

परिणाम:

{ "bodyType" : "Skinny" }

शॉर्टहैंड सिंटैक्स

$cond ऑपरेटर एक शॉर्टहैंड सिंटैक्स भी स्वीकार करता है जो आपके कोड को अधिक संक्षिप्त बनाता है।

शॉर्टहैंड में मूल रूप से if . को हटाना शामिल है , then , और else कीवर्ड।

जब आप ऐसा करते हैं, तो आपको व्यंजकों को एक सरणी में संलग्न करने की आवश्यकता होती है।

इस उदाहरण में, हम शॉर्टहैंड सिंटैक्स का उपयोग करने के लिए पहला उदाहरण फिर से लिखते हैं:

db.pets.aggregate(
  [
    { $project: { 
        _id: 0,
        isCanine: { 
          $cond: [ { "$type": "Dog" }, "Yes", "No" ]
          }
      }
    }
  ]
)

परिणाम:

{ "isCanine" : "Yes" }

और यहाँ शॉर्टहैंड का उपयोग करते हुए दूसरा उदाहरण दिया गया है:

db.pets.aggregate(
  [
    { $project: { 
        _id: 0,
        bodyType: { 
          $cond: [
              { $gte: [ "$weight", "$height" ] }, 
              "Fat", 
              "Skinny" 
              ]
          }
      }
    }
  ]
)

परिणाम:

{ "bodyType" : "Skinny" }

  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. उप-दस्तावेज़ पर नेवला अद्वितीय अनुक्रमणिका

  2. मोंगोडीबी अपडेटऑन ()

  3. मोंगोडब एग्रीगेशन फ्रेमवर्क की व्याख्या करता है

  4. MongoDB में दस्तावेज़ का आकार प्राप्त करने के 2 तरीके

  5. MongoDB bind_ip तब तक काम नहीं करेगा जब तक कि 0.0.0.0 पर सेट न हो जाए