MongoDB में db.collection.findOneAndDelete()
विधि एकल दस्तावेज़ को हटा देती है, और हटाए गए दस्तावेज़ को वापस कर देती है।
यह संग्रह में पहले मेल खाने वाले दस्तावेज़ को हटा देता है जो filter
. से मेल खाता है . sort
पैरामीटर का उपयोग यह प्रभावित करने के लिए किया जा सकता है कि कौन सा दस्तावेज़ हटाया गया है।
collection
भाग उस संग्रह का नाम है जिससे दस्तावेज़ को हटाना है।
उदाहरण
मान लीजिए हमारे पास 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 } { "_id" : 6, "name" : "Fetch", "type" : "Dog", "specs" : { "height" : 400, "weight" : 15, "color" : "brown" } } { "_id" : 7, "name" : "Jake", "type" : "Dog", "awards" : [ "Top Dog", "Best Dog", "Biggest Dog" ] }
हम db.collection.findOneAndDelete()
. का उपयोग कर सकते हैं उन दस्तावेज़ों में से किसी एक को हटाने की विधि।
db.pets.findOneAndDelete(
{ "type": "Cat" }
)
परिणाम:
{ "_id" : 3, "name" : "Meow", "type" : "Cat", "weight" : 7 }
इस मामले में मैंने इसे केवल बिल्लियों तक सीमित करने के लिए एक प्रश्न का उपयोग किया। संग्रह में दो बिल्लियाँ होने के बावजूद केवल एक बिल्ली को हटाया गया था।
आइए संग्रह की जाँच करें।
db.pets.find()
परिणाम:
{ "_id" : 1, "name" : "Wag", "type" : "Dog", "weight" : 20 } { "_id" : 2, "name" : "Bark", "type" : "Dog", "weight" : 10 } { "_id" : 4, "name" : "Scratch", "type" : "Cat", "weight" : 8 } { "_id" : 5, "name" : "Bruce", "type" : "Bat", "weight" : 3 } { "_id" : 6, "name" : "Fetch", "type" : "Dog", "specs" : { "height" : 400, "weight" : 15, "color" : "brown" } } { "_id" : 7, "name" : "Jake", "type" : "Dog", "awards" : [ "Top Dog", "Best Dog", "Biggest Dog" ] }
हम देख सकते हैं कि पहली बिल्ली (दस्तावेज़ 3) हटा दी गई है।
एम्बेडेड दस्तावेज़
यदि आपके पास ऐसे दस्तावेज़ हैं जिनमें एम्बेडेड दस्तावेज़ हैं, तो आप एम्बेडेड दस्तावेज़ों में डेटा क्वेरी करने के लिए निम्न विधियों का उपयोग कर सकते हैं।
- डॉट नोटेशन (उदा.
field.nestedfield: <value>
) - नेस्टेड फ़ॉर्म (उदा. {
field: { nestedfield: <value> } }
) ध्यान दें कि यह विकल्प केवल MongoDB 4.4 से उपलब्ध है।
यहां एक उदाहरण दिया गया है जो एम्बेडेड दस्तावेज़ में क्वेरी करने के लिए डॉट नोटेशन का उपयोग करता है।
db.pets.findOneAndDelete({ "specs.height": 400 })
परिणाम:
{ "_id" : 6, "name" : "Fetch", "type" : "Dog", "specs" : { "height" : 400, "weight" : 15, "color" : "brown" } }
जैसा अपेक्षित था, दस्तावेज़ 6 हटा दिया गया था।
निम्न क्वेरी उसी दस्तावेज़ को हटा देती है, लेकिन इस मामले में यह एम्बेडेड दस्तावेज़ को संदर्भित करने के लिए नेस्टेड प्रपत्र का उपयोग करती है।
db.pets.findOneAndDelete({
"specs" : {
"height" : 400,
"weight" : 15,
"color" : "brown"
}
})
नेस्टेड प्रपत्र का उपयोग करते समय, क्वेरी को संपूर्ण एम्बेडेड दस्तावेज़ से बिल्कुल मेल खाना चाहिए। उदाहरण के लिए, निम्न क्वेरी मेल नहीं खाती:
db.pets.findOneAndDelete({
"specs" : {
"height" : 400
}
})
परिणाम:
null
सरणी
आप सरणी तत्व को उसके सूचकांक या उसके मान द्वारा संदर्भित करके सरणियों में डेटा का संदर्भ दे सकते हैं।
अगर हम सभी कुत्तों को शीर्ष कुत्ता पुरस्कार से हटाना चाहते हैं, तो हम निम्नलिखित प्रश्न लिख सकते हैं (जो उपरोक्त कुत्ते को वापस कर देगा)।
db.pets.findOneAndDelete({
"awards": "Top Dog"
})
परिणाम:
{ "_id" : 7, "name" : "Jake", "type" : "Dog", "awards" : [ "Top Dog", "Best Dog", "Biggest Dog" ] }
आप एलिमेंट इंडेक्स को इस तरह भी निर्दिष्ट कर सकते हैं:
db.pets.findOneAndDelete({
"awards.0": "Top Dog"
})
ऐसा करने के लिए आवश्यक है कि निर्दिष्ट मान निर्दिष्ट अनुक्रमणिका पर हो। इसलिए, निम्न क्वेरी उसी कुत्ते को वापस नहीं करती है।
db.pets.findOneAndDelete({
"awards.1": "Top Dog"
})
ध्यान दें कि सरणियाँ शून्य-आधारित हैं, इसलिए 0 का सूचकांक पहले तत्व को निर्दिष्ट करता है, 1 दूसरे तत्व को निर्दिष्ट करता है, और इसी तरह।
sort
पैरामीटर
आप sort
. का उपयोग कर सकते हैं filter
. द्वारा मिलान किए गए दस्तावेज़ों के लिए सॉर्टिंग क्रम निर्दिष्ट करने के लिए पैरामीटर . यह प्रभावित करेगा कि कौन सा दस्तावेज़ हटाया गया है।
sort
का उपयोग करते समय पैरामीटर, 1
. का मान दस्तावेज़ों को आरोही क्रम में क्रमबद्ध करता है, और -1
. का मान होता है उन्हें अवरोही क्रम में क्रमबद्ध करता है।
तर्क को एक दस्तावेज़ के रूप में प्रदान करने की आवश्यकता है। उदाहरण के लिए, { sort: { "salary": 1 } }
salary
. के आधार पर छाँटें फ़ील्ड आरोही क्रम में।
उदाहरण के लिए, मान लें कि हम employees
. नामक एक संग्रह बनाते हैं निम्नलिखित दस्तावेजों के साथ:
db.employees.insertMany([
{ _id: 1, name: "Sandy", salary: 55000 },
{ _id: 2, name: "Sarah", salary: 128000 },
{ _id: 3, name: "Fritz", salary: 25000 },
{ _id: 4, name: "Chris", salary: 45000 },
{ _id: 5, name: "Beck", salary: 82000 }
])
हम 60000 से कम वेतन वाले दस्तावेज़ों को खोजने के लिए निम्नलिखित कोड चला सकते हैं, फिर उनमें से सबसे कम वेतन वाले दस्तावेज़ को हटा सकते हैं।
db.employees.findOneAndDelete(
{ "salary": { $lt: 60000 } },
{
sort: { "salary": 1 }
}
)
परिणाम:
{ "_id" : 3, "name" : "Fritz", "salary" : 25000 }
जैसा कि अपेक्षित था, सबसे कम वेतन वाले कर्मचारी को हटा दिया गया था।
दस्तावेज़ अब इस तरह दिखते हैं।
db.employees.find()
परिणाम:
{ "_id" : 1, "name" : "Sandy", "salary" : 55000 } { "_id" : 2, "name" : "Sarah", "salary" : 128000 } { "_id" : 4, "name" : "Chris", "salary" : 45000 } { "_id" : 5, "name" : "Beck", "salary" : 82000 }
तो हम देख सकते हैं कि फ़्रिट्ज़ को हटा दिया गया है।
आइए इसे वापस मूल दस्तावेज़ पर वापस लाते हैं।
db.employees.remove({})
db.employees.insertMany([
{ _id: 1, name: "Sandy", salary: 55000 },
{ _id: 2, name: "Sarah", salary: 128000 },
{ _id: 3, name: "Fritz", salary: 25000 },
{ _id: 4, name: "Chris", salary: 45000 },
{ _id: 5, name: "Beck", salary: 82000 }
])
अब वही findOneAndDelete()
चलाते हैं कोड फिर से, लेकिन इस बार हम इसे अवरोही क्रम में क्रमबद्ध करेंगे।
db.employees.findOneAndDelete(
{ "salary": { $lt: 60000 } },
{
sort: { "salary": -1 }
}
)
परिणाम:
{ "_id" : 1, "name" : "Sandy", "salary" : 55000 }
इस बार सैंडी को हटा दिया गया।
आइए फिर से संग्रह की जाँच करें।
db.employees.find()
परिणाम:
{ "_id" : 2, "name" : "Sarah", "salary" : 128000 } { "_id" : 3, "name" : "Fritz", "salary" : 25000 } { "_id" : 4, "name" : "Chris", "salary" : 45000 } { "_id" : 5, "name" : "Beck", "salary" : 82000 }
जैसी उम्मीद थी, सैंडी अब संग्रह में नहीं है।
अधिक जानकारी
db.collection.findOneAndDelete()
विधि अन्य मापदंडों को भी स्वीकार करती है, जैसे कि projection
(वापस जाने के लिए फ़ील्ड का एक सबसेट निर्दिष्ट करने के लिए), maxTimeMS
, और collation
।
अधिक जानकारी के लिए MongoDB दस्तावेज़ देखें।