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

MongoDB अप्सर्ट समझाया गया

MongoDB में कई अपडेट ऑपरेशंस में अप्सर्ट होने की संभावना है। एक अप्सर्ट एक इंसर्ट और एक अपडेट का संयोजन है।

यह इस तरह काम करता है:आप फ़िल्टर मानदंड के आधार पर एक अपडेट ऑपरेशन करते हैं, और यदि कोई मिलान है, तो केवल मिलान किए गए दस्तावेज़ अपडेट किए जाते हैं, लेकिन यदि कोई मेल नहीं है, तो एक नया दस्तावेज़ डाला जाता है।

उदाहरण

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

 { "_id" : 1, "name" : "Wag", "type" : "Dog" }
 { "_id" : 2, "name" : "Bark", "type" : "Dog" }
 { "_id" : 3, "name" : "Meow", "type" : "Cat" } 

हम निम्नलिखित अपडेट ऑपरेशन कर सकते हैं जो upsert . सेट करता है true . के लिए पैरामीटर :

db.pets.updateOne( 
    { name: "Wag" },
    { $set: { type: "Cow" } },
    { upsert: true }
    )

परिणाम:

{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 } 

इस मामले में, एक मेल खाने वाला दस्तावेज़ था (यानी name: "Wag" वाला एक दस्तावेज़ है ) और इसलिए मिलान करने वाले दस्तावेज़ को अद्यतन किया गया था। कुछ भी नहीं डाला गया।

हम इसे इस प्रकार सत्यापित कर सकते हैं:

db.pets.find()

परिणाम:

 { "_id" : 1, "name" : "Wag", "type" : "Cow" }
 { "_id" : 2, "name" : "Bark", "type" : "Dog" }
 { "_id" : 3, "name" : "Meow", "type" : "Cat" } 

पहले दस्तावेज़ में अब type है Cow . का ।

चलिए एक और अपडेट ऑपरेशन चलाते हैं, फिर से upsert: true . का उपयोग करते हुए . लेकिन इस बार, अपडेट करने के लिए कोई मेल खाने वाला दस्तावेज़ नहीं होगा।

db.pets.updateOne( 
    { name: "Bubbles" },
    { $set: { type: "Fish" } },
    { upsert: true }
    )

परिणाम:

 {
 "acknowledged" : true,
 "matchedCount" : 0,
 "modifiedCount" : 0,
 "upsertedId" : ObjectId("5fe1b4c8d9914101694100b7")
 } 

इस उदाहरण में, हम name: "Bubbles" . वाले दस्तावेज़ को खोजने का प्रयास करते हैं लेकिन कोई नहीं मिला।

इस बार हम देख सकते हैं कि matchedCount है 0 , और modifiedCount 0 . भी है . इसका मतलब है कि मौजूदा दस्तावेजों में से कोई भी अपडेट नहीं किया गया था।

हम यह भी देख सकते हैं कि एक upsertedId लौटा दिया गया था, जिसका अर्थ है कि एक दस्तावेज़ को हटा दिया गया था।

आइए दस्तावेज़ों के संग्रह पर एक और नज़र डालें:

db.pets.find()

परिणाम:

 { "_id" : 1, "name" : "Wag", "type" : "Cow" }
 { "_id" : 2, "name" : "Bark", "type" : "Dog" }
 { "_id" : 3, "name" : "Meow", "type" : "Cat" }
 { "_id" : ObjectId("5fe1b4c8d9914101694100b7"), "name" : "Bubbles", "type" : "Fish" } 

हम देख सकते हैं कि एक नया दस्तावेज़ डाला / डाला गया था और इसमें वही आईडी है जो ऊपर बताई गई है।

अप्सर्ट इसलिए हुआ क्योंकि इस बार अपडेट करने के लिए कोई मिलान करने वाला दस्तावेज़ नहीं था (और इसलिए इसके बजाय एक नया डाला गया/अपरक्षित किया गया)।

अगर हमने upsert: true . सेट नहीं किया होता , वह दस्तावेज़ सम्मिलित नहीं किया गया होता।

बल्क अपडेट पर अप्सर्ट करें

बल्क अपडेट करते समय, यदि आप निर्दिष्ट करना चाहते हैं upsert: true , आपको इसे Bulk.find.upsert() . के साथ उपयोग करने की आवश्यकता है ।

इसका उपयोग निम्नलिखित लेखन कार्यों के साथ किया जा सकता है:

  • Bulk.find.replaceOne()
  • Bulk.find.updateOne()
  • Bulk.find.update()

वाक्य रचना इस प्रकार है:

Bulk.find(<query>).upsert().update(<update>);
Bulk.find(<query>).upsert().updateOne(<update>);
Bulk.find(<query>).upsert().replaceOne(<replacement>);

उदाहरण:

var bulk = db.pets.initializeUnorderedBulkOp();
bulk.find( { name: "Bruce" } ).upsert().replaceOne(
   {
     name: "Bruce",
     type: "Bat",
   }
);
bulk.execute();

परिणाम:

 BulkWriteResult({
 "writeErrors" : [ ],
 "writeConcernErrors" : [ ],
 "nInserted" : 0,
 "nUpserted" : 1,
 "nMatched" : 0,
 "nModified" : 0,
 "nRemoved" : 0,
 "upserted" : [
 {
 "index" : 0,
 "_id" : ObjectId("5fe1c179d9914101694100dd")
 }
 ]
 }) 

हम देख सकते हैं कि एक दस्तावेज़ को जोड़ा गया था। हम _id . भी देख सकते हैं जो उस दस्तावेज़ के लिए जनरेट किया गया था।

अब जब हम अपने संग्रह में दस्तावेज़ देखते हैं, तो हम उस नए दस्तावेज़ को देख सकते हैं जो ऊपर किया गया था:

db.pets.find()

परिणाम:

 
 { "_id" : 1, "name" : "Wag", "type" : "Cow" }
 { "_id" : 2, "name" : "Bark", "type" : "Dog" }
 { "_id" : 3, "name" : "Meow", "type" : "Cat" }
 { "_id" : ObjectId("5fe1b4c8d9914101694100b7"), "name" : "Bubbles", "type" : "Fish" }
 { "_id" : ObjectId("5fe1c179d9914101694100dd"), "name" : "Bruce", "type" : "Bat" } 


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. मोंगोडीबी $strLenBytes

  2. DigitalOcean पर MongoDB चलाना

  3. ओपन सोर्स डेटाबेस कैसे तैनात करें

  4. SCUMM:क्लस्टरकंट्रोल में एजेंट-आधारित डेटाबेस मॉनिटरिंग इन्फ्रास्ट्रक्चर

  5. MongoDB:किसी दस्तावेज़ में कुंजियों की संख्या कैसे गिनें?