MongoDB में, आप $pull . का उपयोग कर सकते हैं सरणी से मान निकालने के लिए ऑपरेटर।
$pull का उपयोग करें update() . जैसी विधि के संयोजन के साथ निर्दिष्ट दस्तावेज़ को परिवर्तन के साथ अद्यतन करने के लिए।
उदाहरण
मान लीजिए हमारे पास products . नामक संग्रह है निम्नलिखित दस्तावेजों के साथ:
{ "_id" : 1, "prod" : "Bat", "sizes" : [ "S", "M", "XL", "XXL" ] }
{ "_id" : 2, "prod" : "Hat", "sizes" : [ "S", "L", "XL" ] }
{ "_id" : 3, "prod" : "Cap", "sizes" : [ "XS", "S", "M", "L", "XL" ] } हम दस्तावेज़ 1 में सरणी से एक तत्व को इस तरह से हटा सकते हैं:
db.products.update(
{ _id: 1 },
{ $pull: { sizes: "XXL" } }
) आउटपुट:
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 }) वह संदेश हमें बताता है कि एक दस्तावेज़ का मिलान हुआ और एक (यानी एक ही दस्तावेज़) को संशोधित किया गया।
आइए अब इस संग्रह पर एक नज़र डालते हैं:
db.products.find() परिणाम:
{ "_id" : 1, "prod" : "Bat", "sizes" : [ "S", "M", "XL" ] }
{ "_id" : 2, "prod" : "Hat", "sizes" : [ "S", "L", "XL" ] }
{ "_id" : 3, "prod" : "Cap", "sizes" : [ "XS", "S", "M", "L", "XL" ] }
हम देख सकते हैं कि दस्तावेज़ 1 में सरणी का मान XXL . है निर्दिष्ट के अनुसार हटा दिया गया।
एकाधिक मान हटाएं
हम $in . का उपयोग कर सकते हैं एक से अधिक मान निर्दिष्ट करने के लिए ऑपरेटर जिसे हम सरणी से हटाना चाहते हैं।
उदाहरण:
db.products.update(
{ _id: 3 },
{ $pull: { sizes: { $in: ["XS", "XL"] } } }
) आउटपुट:
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 }) आइए अब संग्रह को फिर से देखें:
db.products.find() परिणाम:
{ "_id" : 1, "prod" : "Bat", "sizes" : [ "S", "M", "XL" ] }
{ "_id" : 2, "prod" : "Hat", "sizes" : [ "S", "L", "XL" ] }
{ "_id" : 3, "prod" : "Cap", "sizes" : [ "S", "M", "L" ] } हम देख सकते हैं कि दस्तावेज़ 3 में दो निर्दिष्ट तत्वों को सरणी से हटा दिया गया है।
सभी दस्तावेज़ अपडेट करें
आप multi: true add जोड़ सकते हैं या updateMany() . का उपयोग करें मानदंड से मेल खाने वाले सभी दस्तावेज़ों को अद्यतन करने की विधि।
जब आप ऐसा करते हैं, तो पहले क्वेरी दस्तावेज़ से किसी भी चयन मानदंड को हटा दें (जो यह निर्दिष्ट करता है कि कौन सा दस्तावेज़/अद्यतन करना है)। दूसरे शब्दों में, update() . के पहले तर्क के रूप में एक खाली दस्तावेज़ का उपयोग करें (या updateMany() ) विधि।
उदाहरण:
db.products.update(
{ },
{ $pull: { sizes: "XL" } },
{ multi: true }
) आउटपुट:
WriteResult({ "nMatched" : 3, "nUpserted" : 0, "nModified" : 2 })
इस मामले में, हम देख सकते हैं कि तीन दस्तावेज़ मेल खाते हैं (क्योंकि संग्रह में तीन दस्तावेज़ हैं), लेकिन केवल दो को संशोधित किया गया था (क्योंकि केवल दो का मान XL था। sizes . में सरणी)।
और संग्रह की दोबारा जांच करें:
db.products.find() परिणाम:
{ "_id" : 1, "prod" : "Bat", "sizes" : [ "S", "M" ] }
{ "_id" : 2, "prod" : "Hat", "sizes" : [ "S", "L" ] }
{ "_id" : 3, "prod" : "Cap", "sizes" : [ "S", "M", "L" ] }
हम देख सकते हैं कि XL . के सभी उदाहरण संग्रह के सभी दस्तावेज़ों से हटा दिया गया है।
दस्तावेज़ों की सरणी
यदि आपके पास ऐसे सरणी हैं जिनमें दस्तावेज़ उनके तत्वों के रूप में हैं, तो आप दस्तावेज़ के भीतर डेटा से मेल खाने वाले मानदंड निर्दिष्ट करके उन दस्तावेज़ों में से किसी को भी हटा सकते हैं।
मान लीजिए कि हमारे पास रेस्तरां नामक एक संग्रह है जो निम्नलिखित दस्तावेज:
{
"_id" : 1,
"name" : "The Rat",
"reviews" : [
{
"name" : "Stanley",
"date" : "04 December, 2020",
"ordered" : "Dinner",
"rating" : 1
},
{
"name" : "Tom",
"date" : "04 October, 2020",
"ordered" : "Lunch",
"rating" : 2
}
]
}
{
"_id" : 2,
"name" : "Yum Palace",
"reviews" : [
{
"name" : "Stacey",
"date" : "08 December, 2020",
"ordered" : "Lunch",
"rating" : 3
},
{
"name" : "Tom",
"date" : "08 October, 2020",
"ordered" : "Breakfast",
"rating" : 4
}
]
}
{
"_id" : 3,
"name" : "Boardwalk Cafe",
"reviews" : [
{
"name" : "Steve",
"date" : "20 December, 2020",
"ordered" : "Breakfast",
"rating" : 5
},
{
"name" : "Lisa",
"date" : "25 October, 2020",
"ordered" : "Dinner",
"rating" : 5
},
{
"name" : "Kim",
"date" : "21 October, 2020",
"ordered" : "Dinner",
"rating" : 5
}
]
}
इस मामले में, reviews . नामक फ़ील्ड दस्तावेजों की एक सरणी शामिल है। प्रत्येक दस्तावेज़ विचाराधीन रेस्तरां की एक अलग समीक्षा है।
हम $pull . का उपयोग कर सकते हैं एक निश्चित मानदंड से मेल खाने वाली समीक्षाओं को हटाने के लिए।
उदाहरण:
db.restaurants.update(
{ },
{ $pull: { reviews: { rating: { $lt: 4 } } } },
{ multi: true }
) आउटपुट:
WriteResult({ "nMatched" : 3, "nUpserted" : 0, "nModified" : 2 })
यह संदेश हमें बताता है कि तीन दस्तावेज़ क्वेरी मानदंड से मेल खाते हैं (क्योंकि हमने सभी दस्तावेज़ों का चयन किया है), और दो दस्तावेज़ संशोधित किए गए थे (क्योंकि दो हमारे $pull से मेल खाते थे। मानदंड)।
आइए प्रभाव देखने के लिए संग्रह को फिर से देखें:
db.restaurants.find().pretty() परिणाम:
{ "_id" : 1, "name" : "The Rat", "reviews" : [ ] }
{
"_id" : 2,
"name" : "Yum Palace",
"reviews" : [
{
"name" : "Tom",
"date" : "08 October, 2020",
"ordered" : "Breakfast",
"rating" : 4
}
]
}
{
"_id" : 3,
"name" : "Boardwalk Cafe",
"reviews" : [
{
"name" : "Steve",
"date" : "20 December, 2020",
"ordered" : "Breakfast",
"rating" : 5
},
{
"name" : "Lisa",
"date" : "25 October, 2020",
"ordered" : "Dinner",
"rating" : 5
},
{
"name" : "Kim",
"date" : "21 October, 2020",
"ordered" : "Dinner",
"rating" : 5
}
]
} हम देख सकते हैं कि केवल 4 और उससे अधिक रेटिंग वाली समीक्षाएं ही शेष हैं। 4 से कम की सभी समीक्षाओं को हटा दिया गया है।