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

फ़ाइल आयात करके MongoDB दस्तावेज़ कैसे हटाएं

mongoimport . के अनुसार संस्करण 100.0.0, आप एक आयातित फ़ाइल के आधार पर MongoDB में दस्तावेज़ हटा सकते हैं। ऐसा करने के लिए, delete . का उपयोग करें मोड।

जब आप delete . का उपयोग करते हैं मोड, यदि किसी आयातित दस्तावेज़ में समान _id है आप जिस संग्रह में आयात कर रहे हैं, उसमें मौजूदा दस्तावेज़ के रूप में मान, मौजूदा दस्तावेज़ हटा दिया जाएगा।

आप अन्य फ़ील्ड या फ़ील्ड भी निर्दिष्ट कर सकते हैं (_id . के अलावा अन्य) फ़ील्ड) यदि आवश्यक हो तो मेल खाने वाला फ़ील्ड होना चाहिए।

उदाहरण

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

db.pets.find()

परिणाम:

{ "_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" : "Bat", "weight" : 3 }

और हमारे पास निम्न JSON फ़ाइल है जिसे pets.json . कहा जाता है :

{"_id":1,"name":"Wag","type":"Dog"}
{"_id":2,"name":"Fluffy","type":"Cat","weight":10}
{"_id":9,"name":"Hop","type":"Kangaroo","weight":60}

निम्न आदेश delete का उपयोग कर JSON फ़ाइल आयात करता है मोड:

mongoimport --db=PetHotel --collection=pets --mode=delete --file=data/pets.json

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

परिणाम जांचें

आइए अब इस संग्रह पर एक नज़र डालते हैं।

db.pets.find()

परिणाम:

{ "_id" : 3, "name" : "Meow", "type" : "Cat", "weight" : 7 }
{ "_id" : 4, "name" : "Scratch", "type" : "Cat", "weight" : 8 }
{ "_id" : 5, "name" : "Bruce", "type" : "Bat", "weight" : 3 }

हम देख सकते हैं कि पहले 2 दस्तावेज़ हटा दिए गए हैं। उन्हें इसलिए हटा दिया गया क्योंकि उनकी _id मान _id . से मेल खाते हैं मौजूदा दस्तावेजों में मूल्य। यह उन अन्य विवरणों के बावजूद है जो आवश्यक रूप से मेल नहीं खाते (जैसे कि दस्तावेज़ 2 के साथ)।

साथ ही, हमारी आयातित फ़ाइल में _id . वाला एक दस्तावेज़ था 9 का लेकिन कोई मेल खाने वाला दस्तावेज़ नहीं था, और इसलिए उसके लिए कुछ भी नहीं हटाया गया था।

अप्सर्ट फ़ील्ड बदलें

आप --upsertFields . का उपयोग कर सकते हैं _id . के अलावा कोई अन्य फ़ील्ड निर्दिष्ट करने के लिए पैरामीटर जिसके खिलाफ मैच करना है। इस पैरामीटर के साथ कई फ़ील्ड का उपयोग करते समय, उन्हें अल्पविराम से अलग की गई सूची के रूप में पास करें।

मान लीजिए कि हमारे पास एक और JSON फ़ाइल है जिसे pets2.json . कहा जाता है और यह इस तरह दिखता है:

{ "name" : "Meow", "type" : "Cat", "weight" : 7 }
{ "name" : "Bubbles", "type" : "Fish", "weight" : 3 }

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

इसलिए हम निम्नलिखित का उपयोग कर सकते हैं mongoimport आदेश:

mongoimport --db=PetHotel --collection=pets --mode=delete --upsertFields=name,type --file=data/pets2.json

आइए अब संग्रह को फिर से देखें:

db.pets.find()

परिणाम:

{ "_id" : 4, "name" : "Scratch", "type" : "Cat", "weight" : 8 }
{ "_id" : 5, "name" : "Bruce", "type" : "Bat", "weight" : 3 }

म्याऊ बिल्ली को हटा दिया गया क्योंकि वह पालतू जानवर MongoDB संग्रह और आयातित दस्तावेज़ दोनों में मौजूद था।

बबल्स फिश का कोई मेल खाने वाला दस्तावेज़ नहीं था और इसलिए उसके लिए कुछ भी नहीं हटाया गया था।

mongoimport की जांच करें

mongoimport MongoDB डेटाबेस टूल्स पैकेज का हिस्सा है। MongoDB डेटाबेस टूल्स MongoDB के साथ काम करने के लिए कमांड-लाइन उपयोगिताओं का एक सूट है।

यदि आप सुनिश्चित नहीं हैं कि आपके पास MongoDB डेटाबेस टूल्स/mongoimport है या नहीं स्थापित है, जाँच करने के लिए अपने टर्मिनल या कमांड प्रॉम्प्ट में निम्न कमांड चलाने का प्रयास करें:

mongoimport --version

यदि आपके पास यह है, तो आपको संस्करण की जानकारी आदि देखनी चाहिए। यदि आपके पास यह नहीं है, तो आप इसे अपने सिस्टम पर स्थापित करने के लिए MongoDB वेबसाइट पर इंस्टॉलेशन निर्देशों का उपयोग कर सकते हैं।

कहां कमांड चलाएं?

मत भूलो, आपको mongoimport चलाने की आवश्यकता है आपके सिस्टम की कमांड लाइन से कमांड (जैसे एक नया टर्मिनल या कमांड प्रॉम्प्ट विंडो)।

उन्हें mongo . से न चलाएं सीप।


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. एक नेवला मॉडल को उस फ़ील्ड के साथ पॉप्युलेट करें जो एक आईडी नहीं है

  2. मैं लाइव MongoDB डेटा को कैसे ब्राउज़ या क्वेरी कर सकता हूं?

  3. बीएसओएन टाइप ऑब्जेक्ट आईडी को जेएसओएन में कनवर्ट करना (मोंगोडब में भंडारण) -जावा

  4. MongoDB $dateFromParts

  5. उत्पादन के लिए एक MongoDB सर्वर तैयार करना