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

मोंगोडीबी फाइंडऑन ()

MongoDB में db.collection.findOne() विधि एक दस्तावेज़ देता है जो संग्रह या दृश्य पर निर्दिष्ट क्वेरी मानदंड को पूरा करता है।

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

findOne() find() . के समान है , सिवाय इसके कि findOne() केवल पहला दस्तावेज़ लौटाता है जो फ़िल्टर मानदंड से मेल खाता है, प्राकृतिक क्रम के अनुसार जो डिस्क पर दस्तावेज़ों के क्रम को दर्शाता है।

find() दूसरी ओर, विधि सभी मेल खाने वाले दस्तावेज़ लौटाती है।

साथ ही, findOne() वास्तविक दस्तावेज़ लौटाता है, जबकि find() प्रत्येक दस्तावेज़ में केवल एक कर्सर लौटाता है। इसलिए, आप findOne() . पर कर्सर विधियों को लागू नहीं कर सकते हैं जैसे आप find() . के साथ कर सकते हैं ।

उदाहरण

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

{ "_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 }

हम findOne() . का उपयोग कर सकते हैं एक दस्तावेज़ वापस करने के लिए।

db.pets.findOne()

परिणाम:

{ "_id" : 1, "name" : "Wag", "type" : "Dog", "weight" : 20 }

यहां, हमने pets . में सभी दस्तावेज़ों की खोज की संग्रह। हम जानते हैं कि इसने सभी दस्तावेज़ों की खोज की क्योंकि हमने कोई फ़िल्टरिंग मानदंड प्रदान नहीं किया था। हमने कोई तर्क भी नहीं दिया।

जब बिना किसी तर्क के कॉल किया जाता है, findOne() संग्रह से सभी दस्तावेज़ों की खोज करता है और मिलान करने वाले दस्तावेज़ के लिए सभी फ़ील्ड लौटाता है।

उपरोक्त करने का दूसरा तरीका इस प्रकार है:

db.pets.findOne({})

इस मामले में हम एक खाली दस्तावेज़ पास करते हैं।

इस खाली दस्तावेज़ में जोड़कर, हम परिणामों को फ़िल्टर करना शुरू कर सकते हैं।

एक प्रश्न प्रदान करें

findOne() . का वास्तविक सिंटैक्स इस तरह जाता है:

db.collection.findOne(query, projection)

इसका मतलब है कि आप एक क्वेरी को पहले तर्क के रूप में और एक प्रक्षेपण को दूसरे के रूप में पास कर सकते हैं।

यदि आप कोई क्वेरी पास करते हैं, तो इसका उपयोग खोज के दायरे को केवल उन दस्तावेज़ों तक फ़िल्टर करने के लिए किया जाता है जो क्वेरी से मेल खाते हैं। एक क्वेरी एक दस्तावेज़ है जिसमें क्वेरी ऑपरेटर होते हैं। जैसा कि हमने पिछले उदाहरण में देखा, एक खाली दस्तावेज़ सभी दस्तावेज़ लौटाता है।

आइए परिणामों को संग्रह में दस्तावेज़ों के सबसेट तक सीमित करें।

db.pets.findOne({"type":"Cat"})

परिणाम:

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

इसने खोज को केवल उन दस्तावेज़ों तक सीमित कर दिया जिनमें type . है Cat . के मान वाला फ़ील्ड , फिर findOne() उस परिणाम से पहला दस्तावेज़ लौटा दिया।

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

आप क्वेरी ऑपरेटरों का भी उपयोग कर सकते हैं। ये आपको अपनी क्वेरी में अधिक विशिष्ट मानदंड लागू करने की अनुमति देते हैं।

उदाहरण:

db.pets.findOne({"weight": { $lt: 10 }})

परिणाम:

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

एम्बेडेड दस्तावेज़

यदि आपके पास ऐसे दस्तावेज़ हैं जिनमें एम्बेडेड दस्तावेज़ हैं, तो आप एम्बेडेड दस्तावेज़ों में डेटा क्वेरी करने के लिए निम्न विधियों का उपयोग कर सकते हैं।

  • डॉट नोटेशन (उदा. field.nestedfield: <value> )
  • नेस्टेड फ़ॉर्म (उदा. { field: { nestedfield: <value> } } ) ध्यान दें कि यह विकल्प केवल MongoDB 4.4 से उपलब्ध है।

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

db.pets.insertOne({
    "_id" : 6,
    "name" : "Fetch",
    "type" : "Dog",
    "specs" : {
        "height" : 400,
        "weight" : 15,
        "color" : "brown"
    }
})

हम एम्बेडेड दस्तावेज़ में क्वेरी करने के लिए डॉट नोटेशन का उपयोग कर सकते हैं।

db.pets.findOne({ "specs.height": 400 })

परिणाम:

{
	"_id" : 6,
	"name" : "Fetch",
	"type" : "Dog",
	"specs" : {
		"height" : 400,
		"weight" : 15,
		"color" : "brown"
	}
}

निम्न क्वेरी वही दस्तावेज़ लौटाती है, इस समय को छोड़कर हम नेस्टेड प्रपत्र का उपयोग करके एम्बेडेड दस्तावेज़ का संदर्भ देते हैं।

db.pets.findOne({ 
    "specs" : {
		"height" : 400,
		"weight" : 15,
		"color" : "brown"
	}
 })

परिणाम:

{
	"_id" : 6,
	"name" : "Fetch",
	"type" : "Dog",
	"specs" : {
		"height" : 400,
		"weight" : 15,
		"color" : "brown"
	}
}

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

db.pets.findOne({ 
    "specs" : {
		"height" : 400
	}
 })

परिणाम:

null

सरणी

आप सरणी तत्व को उसके सूचकांक या उसके मान द्वारा संदर्भित करके सरणियों में डेटा का संदर्भ दे सकते हैं।

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

db.pets.insertOne({
    "_id" : 7,
    "name" : "Jake",
    "type" : "Dog",
    "awards" : [
        "Top Dog",
        "Best Dog",
        "Biggest Dog"
    ]
})

अगर हम सभी कुत्तों को शीर्ष कुत्ते पुरस्कार के साथ ढूंढना चाहते हैं, तो हम निम्नलिखित प्रश्न लिख सकते हैं (जो उपरोक्त कुत्ते को वापस कर देगा)।

db.pets.findOne({ 
    "awards": "Top Dog"
})

परिणाम:

{
	"_id" : 7,
	"name" : "Jake",
	"type" : "Dog",
	"awards" : [
		"Top Dog",
		"Best Dog",
		"Biggest Dog"
	]
}

आप एलिमेंट इंडेक्स को इस तरह भी निर्दिष्ट कर सकते हैं:

db.pets.findOne({ 
    "awards.0": "Top Dog"
})

ऐसा करने के लिए आवश्यक है कि निर्दिष्ट मान निर्दिष्ट अनुक्रमणिका पर हो। इसलिए, निम्न क्वेरी उसी कुत्ते को वापस नहीं करती है।

db.pets.findOne({ 
    "awards.1": "Top Dog"
})

ध्यान दें कि सरणियाँ शून्य-आधारित हैं, इसलिए 0 का सूचकांक पहले तत्व को निर्दिष्ट करता है, 1 दूसरे तत्व को निर्दिष्ट करता है, और इसी तरह।

अनुमान

डिफ़ॉल्ट रूप से, जब आप findOne() . का उपयोग करते हैं, तो सभी दस्तावेज़ फ़ील्ड वापस आ जाते हैं . लेकिन यदि आवश्यक हो तो लौटाए गए फ़ील्ड की संख्या को कम करने के लिए आप अनुमानों का उपयोग कर सकते हैं।

आपको याद होगा कि findOne() . के लिए सिंटैक्स इस तरह जाता है:

db.collection.findOne(query, projection)

जहां query फ़िल्टरिंग मानदंड प्रदान करता है (जो हमने उपरोक्त उदाहरणों में किया है), और projection एक वैकल्पिक प्रक्षेपण है जो निर्दिष्ट करता है कि किस फ़ील्ड को किसी भी मिलान दस्तावेज़ से वापस करना है। इसलिए, यदि हम प्रक्षेपण का उपयोग करना चाहते हैं, तो हम इसे केवल क्वेरी के बाद रखते हैं।

जब आप प्रक्षेपण का उपयोग करते हैं, तो आप शामिल . के लिए फ़ील्ड निर्दिष्ट कर सकते हैं , फ़ील्ड को बहिष्कृत करना , अथवा दोनों। ऐसा करने के लिए, फ़ील्ड का नाम और या तो 1 . सूचीबद्ध करें (इसे शामिल करने के लिए) या 0 (इसे बाहर करने के लिए)।

शामिल करने के लिए फ़ील्ड निर्दिष्ट करने के लिए प्रक्षेपण का उपयोग करने का एक उदाहरण यहां दिया गया है:

db.pets.findOne({}, { name: 1, type: 1 })

परिणाम:

{ "_id" : 1, "name" : "Wag", "type" : "Dog" }

ध्यान दें कि _id भले ही हमने इसे अपने प्रोजेक्शन में शामिल नहीं किया हो, फिर भी फ़ील्ड लौटा दी जाती है। यह फ़ील्ड एक अपवाद है, और डिफ़ॉल्ट रूप से शामिल है।

अगर आप _id नहीं चाहते हैं फ़ील्ड लौटाने के लिए, आपको उसे स्पष्ट रूप से बाहर करना होगा।

db.pets.findOne({}, { _id: 0, name: 1, type: 1 })

परिणाम:

{ "name" : "Wag", "type" : "Dog" }

यहां एक और उदाहरण दिया गया है, इस बार हम केवल निर्दिष्ट करते हैं कि किन क्षेत्रों को बाहर करना है।

db.pets.findOne({}, { _id: 0, weight: 0, specs: 0, awards: 0 })

परिणाम:

{ "name" : "Wag", "type" : "Dog" }

और अनुमान

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

उदाहरण:

db.pets.findOne({}, { 
    "_id": 0,
    "n": "$name", 
    "t": "$type", 
    "w": "$weight" 
    })

परिणाम:

{ "n" : "Wag", "t" : "Dog", "w" : 20 }

यहां, हमने फ़ील्ड नामों का नाम बदल दिया। हमने $fieldName का उपयोग करते हुए स्ट्रिंग अक्षर के रूप में प्रत्येक फ़ील्ड के लिए एक नया नाम निर्दिष्ट करके ऐसा किया है। उस फ़ील्ड मान को आउटपुट करने के लिए सिंटैक्स। परिणाम कुछ ऐसा है जैसे SQL में उपनाम का उपयोग करना।

अधिक जानकारी

अधिक जानकारी के लिए MongoDB दस्तावेज़ देखें।


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. मोंगोडब समुच्चय (गिनती) एक साथ कई क्षेत्रों पर

  2. MongoDB चेंज स्ट्रीम के साथ रीयल टाइम डेटा स्ट्रीमिंग

  3. नेवला में एक उप-दस्तावेज़ खोजें

  4. MongoDB आंतरिक सूची में कोई तत्व कैसे सम्मिलित करें?

  5. सरणी पर mongoDB अपरर्ट