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

मोंगो में कुछ क्षेत्रों को स्ट्रिंग से ऐरे में परिवर्तित करना

हम $type का इस्तेमाल नहीं कर सकते ऑपरेटर हमारे दस्तावेज़ों को यहाँ फ़िल्टर करेगा क्योंकि हमारे सरणी में तत्वों का प्रकार "स्ट्रिंग" है और जैसा कि दस्तावेज़ीकरण में बताया गया है:

लेकिन सौभाग्य से MongoDB $exists . भी प्रदान करता है ऑपरेटर जिसका उपयोग यहां संख्यात्मक सरणी अनुक्रमणिका के साथ किया जा सकता है।

अब हम उन दस्तावेज़ों को कैसे अपडेट कर सकते हैं?

ठीक है, MongoDB संस्करण <=3.2 से, हमारे पास एकमात्र विकल्प है mapReduce() लेकिन पहले MongoDB की आगामी रिलीज़ में दूसरे विकल्प को देखें।

MongoDB 3.4 से शुरू करके, हम $project कर सकते हैं हमारे दस्तावेज़ और $split . का उपयोग करें ऑपरेटर हमारे स्ट्रिंग को सबस्ट्रिंग की एक सरणी में विभाजित करने के लिए।

ध्यान दें कि केवल उन "टैग" को विभाजित करने के लिए जो स्ट्रिंग हैं, हमें एक तार्किक की आवश्यकता है। $cond केवल स्ट्रिंग वाले मानों को विभाजित करने के लिए ion प्रसंस्करण। यहां शर्त है $eq जो सत्य . का मूल्यांकन करते हैं जब $type फ़ील्ड का "string" . के बराबर है . वैसे $type यहाँ 3.4 में नया है।

अंत में हम $out पाइपलाइन चरण ऑपरेटर। लेकिन हमें $project . में अन्य फ़ील्ड के समावेश को स्पष्ट रूप से निर्दिष्ट करने की आवश्यकता है मंच

db.collection.aggregate(
     [
        { "$project": { 
            "tags": { 
                "$cond": [ 
                    { "$eq": [ 
                        { "$type": "$tags" }, 
                        "string"
                    ]}, 
                    { "$split": [ "$tags", " " ] }, 
                    "$tags" 
                ] 
            } 
        }},
        { "$out": "collection" }
    ]
)

mapReduce . के साथ , हमें Array का उपयोग करने की आवश्यकता है। प्रोटोटाइप.स्प्लिट () हमारे मैप फ़ंक्शन . में सबस्ट्रिंग की सरणी को उत्सर्जित करने के लिए . हमें "क्वेरी" विकल्प का उपयोग करके अपने दस्तावेज़ों को फ़िल्टर करने की भी आवश्यकता है। वहां से हमें "परिणाम" सरणी और $set . को पुनरावृत्त करना होगा बल्कराइट () 3.2 में नया तरीका या अब बहिष्कृत Bulk() अगर हम 2.6 या 3.0 पर हैं जैसा कि दिखाया गया है यहां।

db.collection.mapReduce(
    function() { emit(this._id, this.tags.split(" ")); }, 
    function(key, value) {}, 
    { 
        "out": { "inline": 1 }, 
        "query": { 
            "tags.0": { "$exists": false }, 
            "tags": { "$type": 2 }
        }
    }
)['results']



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. नेवला:गहरी आबादी (आबादी वाले क्षेत्र में आबाद)

  2. MongoDB जावा ड्राइवर अपडेट उप-दस्तावेज़

  3. MongoDB findOneAndDelete ()

  4. नेवला रिटर्न परिणाम नोड जेएस चर के लिए असाइन करें

  5. त्रुटि:अपडेट ऑपरेशन दस्तावेज़ में परमाणु ऑपरेटर होना चाहिए, जब अपडेटऑन चल रहा हो