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

लूप के बिना ईमेल जैसे अद्वितीय आईडी द्वारा विभिन्न मूल्यों के साथ नेवला अद्यतन कई

आप प्रत्येक इनपुट को बल्क राइट के साथ उपयोग के लिए आकार देने के लिए Array.map का उपयोग कर सकते हैं।

ऐसा लगता है कि आप जिस व्यवहार का वर्णन कर रहे हैं वह email . का उपयोग कर रहा है प्रत्येक दस्तावेज़ की पहचान करने के लिए फ़ील्ड।

आपने यह नहीं बताया कि दस्तावेज़ों में अन्य क्षेत्रों के साथ क्या होना चाहिए। यदि आप अन्य क्षेत्रों को अकेला छोड़ना चाहते हैं, तो $set . का उपयोग करें आने वाले डेटा में उल्लिखित किसी भी फ़ील्ड को हटाने के लिए, $replace . का उपयोग करें ।

शेल में ऐसा दिखता है:

PRIMARY> db.users.find()
{ "_id" : 1, "email" : "[email protected]", "name" : "one" }
{ "_id" : 2, "email" : "[email protected]", "name" : "two" }
{ "_id" : 3, "email" : "[email protected]", "name" : "three" }

PRIMARY> let users = [     
  { email: "[email protected]", name: "oneeee" },       
  { email: "[email protected]", name: "twoooo" },       
  { email: "[email protected]", name: "three" },       
  { email: "[email protected]", name: "four" }   
]

PRIMARY> let bulkUpdate = db.users.initializeUnorderedBulkOp()

PRIMARY> users.forEach(u => bulkUpdate.find({email:u.email}).upsert().update({$set:u}))

PRIMARY> bulkUpdate.execute()
BulkWriteResult({
    "writeErrors" : [ ],
    "writeConcernErrors" : [ ],
    "nInserted" : 0,
    "nUpserted" : 1,
    "nMatched" : 3,
    "nModified" : 2,
    "nRemoved" : 0,
    "upserted" : [
        {
            "index" : 3,
            "_id" : ObjectId("5f5e79ff28ee536df4c4a88e")
        }
    ]
})

PRIMARY> db.users.find()
{ "_id" : 1, "email" : "[email protected]", "name" : "oneeee" }
{ "_id" : 2, "email" : "[email protected]", "name" : "twoooo" }
{ "_id" : 3, "email" : "[email protected]", "name" : "three" }
{ "_id" : ObjectId("5f5e79ff28ee536df4c4a88e"), "email" : "[email protected]", "name" : "four" }

Model.bulkWrite() पर एक नज़र डालें नेवला में इसे कैसे करें के उदाहरण के लिए।




  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. मैं Laravel में संपादन दृश्य में रिकॉर्ड ड्रोम डेटाबेस कैसे ला सकता हूं?

  2. मोंगोडीबी $ltrim

  3. क्या नेवला प्री ('सेव') में संपत्ति के पिछले मूल्य तक पहुंच प्रदान करता है?

  4. Node.js mongodb . में सम नेस्टेड सरणी

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