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

मोंगोडीबी $मिनट

MongoDB का $min है ऑपरेटर जो आपको किसी फ़ील्ड के मान को केवल तभी अपडेट करने की अनुमति देता है जब निर्दिष्ट मान फ़ील्ड के वर्तमान मान से कम हो।

दूसरे शब्दों में, यदि $min मान दस्तावेज़ में वर्तमान मान से कम है, $min मूल्य का प्रयोग किया जाता है। अन्यथा, दस्तावेज़ का मूल्य अपरिवर्तित रहता है।

उदाहरण

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

{ "_id" : 1, "strokes" : 70 } 

और कल्पना करें कि हम गोल्फ के प्रत्येक खेल के बाद नवीनतम स्कोर के साथ दस्तावेज़ को अपडेट करते हैं। इस मामले में, हम केवल strokes चाहते हैं यदि हमारा नवीनतम स्कोर कम था तो फ़ील्ड को अपडेट किया जाना चाहिए हमारे पिछले स्कोर की तुलना में।

इस मामले में हम $min . का उपयोग कर सकते हैं उस परिणाम को प्राप्त करने के लिए ऑपरेटर।

उदाहरण:

db.golf.update( 
  { _id: 1 }, 
  { $min: { strokes: 64 } } 
)

आउटपुट:

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

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

आइए फिर से संग्रह की जाँच करें।

db.golf.find()

परिणाम:

{ "_id" : 1, "strokes" : 64 }

हम देख सकते हैं कि strokes फ़ील्ड को नए मान के साथ अपडेट किया गया था। ऐसा इसलिए है क्योंकि 64 इसके पिछले मान 70 से कम है।

जब मान अधिक हो

जब मान $min . के साथ निर्दिष्ट किया गया हो दस्तावेज़ में मौजूदा मान से अधिक है, कुछ भी अपडेट नहीं किया गया है।

उदाहरण:

db.golf.update( 
  { _id: 1 }, 
  { $min: { strokes: 72 } } 
)

आउटपुट:

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 0 })

हम संदेश से देख सकते हैं कि कुछ भी अपडेट नहीं किया गया था।

आइए फिर से संग्रह की जाँच करें।

db.golf.find()

परिणाम:

{ "_id" : 1, "strokes" : 64 }

हम देख सकते हैं कि मान 64 पर बना हुआ है, भले ही हमने इसे 72 में अपडेट करने का प्रयास किया। यह अपेक्षित है, क्योंकि हमने $min का उपयोग किया है ।

तारीख

आप $min . का उपयोग कर सकते हैं दिनांक फ़ील्ड पर।

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

{ "_id" : 1, "firstDiscovered" : ISODate("2000-01-01T00:00:00Z") } 

आइए उस तारीख के साथ तारीख को अपडेट करने का प्रयास करें जो दस्तावेज़ में वर्तमान तिथि के बाद की है।

db.species.update( 
  { _id: 1 }, 
  { $min: { firstDiscovered: new Date("2001-01-01") } } 
)

यहां, हम वर्ष को 2000 . से अपडेट करने का प्रयास करते हैं करने के लिए 2001 . यह देखते हुए कि नई तारीख मौजूदा तारीख के बाद की है, हमें निम्नलिखित मिलते हैं:

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 0 })

कुछ भी अपडेट नहीं किया गया।

आइए संग्रह की जाँच करें:

db.species.find()

परिणाम:

{ "_id" : 1, "firstDiscovered" : ISODate("2000-01-01T00:00:00Z") } 

जैसा अपेक्षित था, वही दिनांक मान बना रहता है।

आइए अब इसे पहले की तारीख से अपडेट करने का प्रयास करें।

db.species.update( 
  { _id: 1 }, 
  { $min: { firstDiscovered: new Date("1999-01-01") } } 
)

आउटपुट:

WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

हम संदेश से देख सकते हैं कि दस्तावेज़ अपडेट किया गया था।

आइए देखें।

db.species.find()

परिणाम:

{ "_id" : 1, "firstDiscovered" : ISODate("1999-01-01T00:00:00Z") } 

तारीख को उम्मीद के मुताबिक अपडेट किया गया था।


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. mongodb . में तिथियों के अनुसार समूह

  2. एक संबंधपरक डेटाबेस की तुलना में MongoDB जैसे स्कीमा-मुक्त डेटाबेस का उपयोग करने के क्या लाभ हैं?

  3. मैं अधिकतम दस्तावेज़ आकार से अधिक के बिना एकत्रीकरण कैसे लिख सकता हूं?

  4. मोंगो डीबी ऑब्जेक्ट आईडी जेएसओएन सीरिएलाइज़र का उपयोग करके deserializing

  5. रेल में मोंगोइड के साथ मोंगोडीबी - भू-स्थानिक अनुक्रमण