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

मोंगोडीबी सम्मिलित करेंकई ()

MongoDB में db.collection.insertMany() विधि एक संग्रह में कई दस्तावेज़ सम्मिलित करती है।

collection दस्तावेज़ों को सम्मिलित करने के लिए संग्रह का नाम भाग है।

उदाहरण

यहां db.collection.insertMany() . का उपयोग करने का एक उदाहरण दिया गया है pets . नामक संग्रह में अनेक दस्तावेज़ सम्मिलित करने के लिए :

db.pets.insertMany([
    { _id: 1, name: "Wag", type: "Dog" },
    { _id: 2, name: "Bark", type: "Dog" },
    { _id: 3, name: "Meow", type: "Cat" }
    ])

परिणाम:

{ "acknowledged" : true, "insertedIds" : [ 1, 2, 3 ] } 

db.collection.insertMany() विधि एक दस्तावेज़ देता है जिसमें शामिल हैं:

  • एक बूलियन acknowledged true . के रूप में यदि ऑपरेशन लिखित चिंता या false . के साथ चलता है अगर लेखन चिंता अक्षम थी।
  • _id की एक सरणी प्रत्येक सफलतापूर्वक डाले गए दस्तावेज़ के लिए मान।

अब अगर हम db.collection.find() . का उपयोग करते हैं संग्रह को देखने के लिए, हम नए जोड़े गए दस्तावेज़ देखेंगे।

db.pets.find()

परिणाम:

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

इस मामले में, संग्रह में केवल हमारे तीन दस्तावेज़ हैं, और इसलिए केवल ये दस्तावेज़ लौटाए गए।

हालांकि, अगर संग्रह बड़ा था, तो हम परिणाम को केवल उन दस्तावेज़ों तक सीमित करने के लिए दस्तावेज़ आईडी का उपयोग कर सकते थे जिनमें हम रुचि रखते हैं।

db.pets.find({_id: {$in: [1,2,3]}})

परिणाम:

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

यदि संग्रह मौजूद नहीं है तो क्या होगा?

यदि संग्रह मौजूद नहीं है, तो इसे बनाया जाता है, और इसमें दस्तावेज़ जोड़े जाते हैं।

यदि संग्रह पहले से मौजूद है, तो दस्तावेज़ों को बस इसमें जोड़ दिया जाता है (बशर्ते उनका _id मान किसी मौजूदा के साथ विरोध नहीं करते हैं)।

जब मैंने यह उदाहरण बनाया, तो संग्रह मौजूद नहीं था, और इसलिए सम्मिलित ऑपरेशन ने इसे बनाया।

_id फ़ील्ड

_id MongoDB में फ़ील्ड एक विशिष्ट पहचानकर्ता फ़ील्ड है।

जैसा कि पिछले उदाहरण में दिखाया गया है, आप अपना खुद का _id प्रदान कर सकते हैं दस्तावेज़ में फ़ील्ड। यदि आप करते हैं, तो इसका मान संग्रह के भीतर अद्वितीय होना चाहिए। ऐसा इसलिए है क्योंकि आपका _id फ़ील्ड का उपयोग दस्तावेज़ के विशिष्ट पहचानकर्ता के रूप में किया जाएगा।

यहां _id प्रदान किए बिना दस्तावेज़ डालने का एक उदाहरण दिया गया है फ़ील्ड।

db.pets.insertMany([
    { name: "Bruce", type: "Bat" },
    { name: "Sweetie", type: "Honey Badger" }
    ])

परिणाम:

{
	"acknowledged" : true,
	"insertedIds" : [
		ObjectId("5fe30ef737b49e0faf1af215"),
		ObjectId("5fe30ef737b49e0faf1af216")
	]
}

_id दस्तावेजों के मूल्य वापस कर दिए जाते हैं। हम इनका उपयोग केवल हमारे द्वारा डाले गए दस्तावेज़ों के संग्रह को खोजने के लिए कर सकते हैं।

लेकिन इस मामले में, आइए पूरे संग्रह को देखें।

db.pets.find()

परिणाम:

{ "_id" : 1, "name" : "Wag", "type" : "Dog" }
{ "_id" : 2, "name" : "Bark", "type" : "Dog" }
{ "_id" : 3, "name" : "Meow", "type" : "Cat" }
{ "_id" : ObjectId("5fe30ef737b49e0faf1af215"), "name" : "Bruce", "type" : "Bat" }
{ "_id" : ObjectId("5fe30ef737b49e0faf1af216"), "name" : "Sweetie", "type" : "Honey Badger" }

हम देख सकते हैं कि हमारे दो नए दस्तावेज़ संग्रह में शामिल हैं।

ordered पैरामीटर

db.collection.insertMany() विधि ordered . को भी स्वीकार करती है पैरामीटर। यह एक बूलियन पैरामीटर है जिसका डिफ़ॉल्ट मान true . है .

ordered पैरामीटर निर्दिष्ट करता है कि इंसर्ट ऑपरेशन ऑर्डर किया जाना चाहिए या अनियंत्रित।

अगर ordered false पर सेट है , दस्तावेज़ एक अनियंत्रित प्रारूप में डाले जाते हैं और mongod . द्वारा पुन:व्यवस्थित किए जा सकते हैं प्रदर्शन बढ़ाने के लिए।

ऑर्डर किए गए इंसर्ट के साथ, यदि किसी एक दस्तावेज़ को सम्मिलित करने के दौरान कोई त्रुटि होती है, तो MongoDB सरणी में शेष दस्तावेज़ों को संसाधित किए बिना त्रुटि पर वापस आ जाता है।

अनियंत्रित इंसर्ट के साथ, यदि किसी एक दस्तावेज़ को सम्मिलित करने के दौरान कोई त्रुटि होती है, तो MongoDB शेष दस्तावेज़ों को सरणी में सम्मिलित करना जारी रखता है।

अधिक जानकारी

db.collection.insertMany() विधि एक writeConcern को भी स्वीकार करती है तर्क, जो लेखन कार्यों के लिए MongoDB से अनुरोध की गई पावती के स्तर का वर्णन करता है।

db.collection.insertMany() . के लिए MongoDB दस्तावेज़ देखें अधिक जानकारी के लिए।


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. मोंगोडब एकत्रीकरण छँटाई

  2. क्या फ़ाइल में MongoDB शेल आउटपुट को 'सुंदर' प्रिंट करने का कोई तरीका है?

  3. MongoDB, MapReduce और छँटाई

  4. MongoDB डेटाबेस कनेक्शन को खुला रखना

  5. मेरे मोंगोडब की मरम्मत कैसे करें?