MongoDB डेटाबेस टूल्स में mongoexport . नामक एक उपयोगिता शामिल है जो आपको MongoDB डेटा को CSV या JSON फ़ाइल में निर्यात करने में सक्षम बनाता है।
यह लेख आपको mongoexport . का उपयोग करने का तरीका दिखाता है MongoDB संग्रह को JSON फ़ाइल में निर्यात करने के लिए।
सिंटैक्स
mongoexport . के लिए सिंटैक्स इस तरह जाता है:
mongoexport --collection=<coll> <options> <connection-string>
आपको mongoexport चलाने की जरूरत है आपके सिस्टम की कमांड लाइन से कमांड (जैसे एक नया टर्मिनल या कमांड प्रॉम्प्ट विंडो)।
mongoexport न चलाएं mongo . से आदेश सीप।
संग्रह निर्यात करें
निम्न उदाहरण कोड MongoDB से JSON फ़ाइल में एक संग्रह निर्यात करता है:
mongoexport --db=PetHotel --collection=pets --out=data/pets.json
यह pets . नामक संग्रह को निर्यात करता है PetHotel . से pets.json . नामक फ़ाइल के लिए डेटाबेस data/ में फ़ोल्डर।
यदि फ़ोल्डर मौजूद नहीं है, तो इसे बनाया गया है। फ़ाइल के साथ ही। वैसे, यह मानता है कि निर्दिष्ट स्थान पर फ़ाइल लिखने में कोई अनुमति समस्या नहीं है।
इस उदाहरण में मैंने कोई होस्ट, पोर्ट, प्रमाणीकरण आदि निर्दिष्ट नहीं किया है, इसलिए यह डिफ़ॉल्ट लोकलहोस्ट पोर्ट नंबर 27017 पर चल रहे MongoDB इंस्टेंस से संग्रह को निर्यात करता है। ।
उपरोक्त उदाहरण को इस प्रकार भी लिखा जा सकता है:
mongoexport --db=PetHotel --collection=pets --type=json --fields=_id,name,type,weight --out=data/pets.json
इस मामले में हमने --type जोड़ा है पैरामीटर और एक --fields यह निर्दिष्ट करने के लिए कि JSON फ़ाइल में कौन-से फ़ील्ड शामिल करने हैं।
नीचे हमारे द्वारा प्रदान किए गए मापदंडों की व्याख्या है।
| पैरामीटर | <थ>विवरण|
|---|---|
--db या -d | उस डेटाबेस को निर्दिष्ट करता है जिसमें वह संग्रह होता है जिसे हम निर्यात करना चाहते हैं। इस मामले में, डेटाबेस को PetHotel . कहा जाता है . यह पैरामीटर वैकल्पिक रूप से -d . का उपयोग करके पारित किया जा सकता है (--db . के बजाय )। |
--collection या -c | उस संग्रह को निर्दिष्ट करता है जिसे हम निर्यात करना चाहते हैं। इस मामले में, संग्रह को pets . कहा जाता है . यह पैरामीटर वैकल्पिक रूप से -c . के रूप में पारित किया जा सकता है (--collection . के बजाय )। |
--type | निर्यात की गई फ़ाइल प्रकार निर्दिष्ट करता है। इस मामले में हम json . निर्दिष्ट करते हैं इसे JSON फ़ाइल में निर्यात करने के लिए। json डिफ़ॉल्ट मान है, इसलिए यदि हम इस पैरामीटर को निर्दिष्ट नहीं करते हैं, तो फ़ाइल एक JSON फ़ाइल के रूप में आउटपुट होती है। |
--fields | उन फ़ील्ड को निर्दिष्ट करता है जिन्हें हम निर्यात करना चाहते हैं। हमारे पास संग्रह में सभी फ़ील्ड निर्यात करने का विकल्प है, या बस कुछ को। एक से अधिक फ़ील्ड नामों को अल्पविराम से अलग करें। JSON को निर्यात करते समय, फ़ील्ड नाम निर्दिष्ट करना वैकल्पिक है (CSV के विपरीत)। |
--out | निर्यात की गई फ़ाइल का नाम निर्दिष्ट करता है और यह कहां स्थित होगा। यदि आप फ़ाइल नाम निर्दिष्ट नहीं करते हैं, mongoexport मानक आउटपुट के लिए डेटा लिखता है (stdout )। |
निर्यात की गई फ़ाइल की जांच करें
आइए सत्यापित करें कि निर्यात कार्रवाई अपेक्षित रूप से काम कर रही है।
सबसे पहले, आइए मूल संग्रह की जांच करें।
use PetHotel
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 }
{ "_id" : 6, "name" : "Fetch", "type" : "Dog", "weight" : 17 }
{ "_id" : 7, "name" : "Jake", "type" : "Dog", "weight" : 30 } इसलिए हम देख सकते हैं कि 7 पालतू जानवर हैं, सभी समान फ़ील्ड वाले हैं जिन्हें हमने अपने निर्यात ऑपरेशन में निर्दिष्ट किया है।
अब एक्सपोर्ट की गई फाइल को खोलें pets.json अंदर क्या है देखने के लिए:
{"_id":1.0,"name":"Wag","type":"Dog","weight":20.0}
{"_id":2.0,"name":"Bark","type":"Dog","weight":10.0}
{"_id":3.0,"name":"Meow","type":"Cat","weight":7.0}
{"_id":4.0,"name":"Scratch","type":"Cat","weight":8.0}
{"_id":5.0,"name":"Bruce","type":"Bat","weight":3.0}
{"_id":6.0,"name":"Fetch","type":"Dog","weight":17.0}
{"_id":7.0,"name":"Jake","type":"Dog","weight":30.0} सभी डेटा निर्यातित फ़ाइल में अपेक्षित के रूप में है।
कम फ़ील्ड
आप --fields . का उपयोग कर सकते हैं पैरामीटर निर्दिष्ट करने के लिए कि आप किन क्षेत्रों को निर्यात करना चाहते हैं।
जब आप JSON फ़ाइलों पर ऐसा करते हैं, तो _id फ़ील्ड हमेशा निर्यात की जाती है (भले ही आप इसे निर्यात करने के लिए फ़ील्ड की सूची में शामिल न करें)।
उदाहरण:
mongoexport --db=PetHotel --collection=pets --fields=name,type --out=data/pets.json इस मामले में मैं निर्यात करने के लिए दो फ़ील्ड निर्दिष्ट करता हूं।
जब मैं निर्यात की गई फ़ाइल खोलता हूं, तो मैं देख सकता हूं कि उन दोनों क्षेत्रों को निर्यात किया गया है, प्लस _id फ़ील्ड:
{"_id":1.0,"name":"Wag","type":"Dog"}
{"_id":2.0,"name":"Bark","type":"Dog"}
{"_id":3.0,"name":"Meow","type":"Cat"}
{"_id":4.0,"name":"Scratch","type":"Cat"}
{"_id":5.0,"name":"Bruce","type":"Bat"}
{"_id":6.0,"name":"Fetch","type":"Dog"}
{"_id":7.0,"name":"Jake","type":"Dog"} पहुंच नियंत्रण/प्रमाणीकरण
यदि आप लोकलहोस्ट का उपयोग नहीं कर रहे हैं, तो आप --host . का उपयोग कर सकते हैं होस्ट निर्दिष्ट करने के लिए पैरामीटर, और --port पोर्ट निर्दिष्ट करने के लिए। आप --username . का भी उपयोग कर सकते हैं उपयोगकर्ता नाम निर्दिष्ट करने के लिए पैरामीटर और --password पासवर्ड के लिए। यदि आप पासवर्ड पैरामीटर को छोड़ देते हैं, तो आपको इसके लिए संकेत दिया जाएगा। एक --authenticationDatabase भी है प्रमाणीकरण डेटाबेस निर्दिष्ट करने के लिए पैरामीटर जहां उपयोगकर्ता बनाया गया है।
उदाहरण:
mongoexport --host=myhost.example.com --port=37017 --username=homer --authenticationDatabase=admin --db=PetHotel --collection=pets --out=data/pets.json mongoexport की जांच करें
mongoexport MongoDB डेटाबेस टूल्स पैकेज का हिस्सा है। MongoDB डेटाबेस टूल्स MongoDB के साथ काम करने के लिए कमांड-लाइन उपयोगिताओं का एक सूट है।
यदि आप सुनिश्चित नहीं हैं कि आपके पास MongoDB डेटाबेस टूल्स/mongoexport है या नहीं स्थापित है, जाँच करने के लिए अपने टर्मिनल या कमांड प्रॉम्प्ट में निम्न कमांड चलाने का प्रयास करें:
mongoexport --version यदि आपके पास है, तो आपको संस्करण की जानकारी आदि देखनी चाहिए। यदि आपके पास यह नहीं है, तो आप इसे अपने सिस्टम पर स्थापित करने के लिए MongoDB वेबसाइट पर इंस्टॉलेशन निर्देशों का उपयोग कर सकते हैं।
कहां कमांड चलाएं?
मत भूलो, आपको mongoexport चलाने की आवश्यकता है आपके सिस्टम की कमांड लाइन से कमांड (जैसे एक नया टर्मिनल या कमांड प्रॉम्प्ट विंडो)।
उन्हें mongo . से न चलाएं सीप।