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

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

MongoDB में, $minute एग्रीगेशन पाइपलाइन ऑपरेटर दिनांक के मिनट के हिस्से को 0 . के बीच की संख्या के रूप में लौटाता है और 59

आप परिणाम के लिए उपयोग करने के लिए वैकल्पिक रूप से एक समय क्षेत्र निर्दिष्ट कर सकते हैं।

$minute ऑपरेटर या तो एक तिथि स्वीकार करता है (या तो एक तिथि, एक टाइमस्टैम्प, या एक ऑब्जेक्ट आईडी के रूप में), या एक दस्तावेज जो उपयोग करने के लिए दिनांक और समय क्षेत्र निर्दिष्ट करता है।

उदाहरण

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

{
	"_id" : ObjectId("600631c7c8eb4369cf6ad9c8"),
	"name" : "Fetch",
	"born" : ISODate("2020-12-31T23:30:15.123Z")
}

हम born . से मिनट के हिस्से को निकालने के लिए निम्नलिखित कोड चला सकते हैं उस दस्तावेज़ में फ़ील्ड।

db.pets.aggregate(
  [
    {
      $project:
        {
          _id: 0,
          birthMinute: { $minute: "$born" }
        }
    }
  ]
)

परिणाम:

{ "birthMinute" : 30 } 

यहाँ, मैंने birthMinute . का उपयोग किया है वापस जाने के लिए फ़ील्ड नाम के रूप में, लेकिन यह कुछ भी हो सकता था (जैसे कि minutesAtBirth , minutes , आदि)।

_id MongoDB में अनुमानों का उपयोग करते समय फ़ील्ड डिफ़ॉल्ट रूप से लौटा दी जाती है, लेकिन इस उदाहरण में मैंने स्पष्ट रूप से _id छुपाया है _id: 0 . का उपयोग करके फ़ील्ड ।

समयक्षेत्र निर्दिष्ट करें

आप $minute . के आउटपुट के लिए उपयोग करने के लिए एक समय क्षेत्र निर्दिष्ट कर सकते हैं ऑपरेटर।

जब आप ऐसा करते हैं, तो तर्क $minute . तक पहुंच जाता है निम्नलिखित रूप का होना चाहिए:

{ date: <dateExpression>, timezone: <tzExpression> }

जहां <dateExpression> उपयोग करने की तिथि है, और <tzExpression> उपयोग करने के लिए समय क्षेत्र है।

ओल्सन टाइमज़ोन पहचानकर्ता (उदा. "Europe/London" का उपयोग करके समयक्षेत्र निर्दिष्ट किया जा सकता है , "GMT" ) या UTC ऑफ़सेट (उदा. "+02:30" , "-1030" )।

ओल्सन टाइमज़ोन आइडेंटिफ़ायर

यहां एक उदाहरण दिया गया है जो मिनट को दो अलग-अलग टाइमज़ोन में आउटपुट करता है, प्रत्येक ओल्सन टाइमज़ोन आईडी का उपयोग करता है:

db.pets.aggregate(
  [
    {
      $project: {
          _id: 0,
          kabul: { 
            $minute: { date: "$born", timezone: "Asia/Kabul" }
            },
          katmandu: { 
            $minute: { date: "$born", timezone: "Asia/Katmandu" }
            }
        }
    }
  ]
)

परिणाम:

{ "kabul" : 0, "katmandu" : 15 } 

UTC ऑफ़सेट

इस उदाहरण में हम UTC ऑफ़सेट का उपयोग करते हैं।

db.pets.aggregate(
  [
    {
      $project: {
          _id: 0,
          "utcOffset+04:30": { 
            $minute: { date: "$born", timezone: "+04:30" }
            },
          "utcOffset+05:45": { 
            $minute: { date: "$born", timezone: "+05:45" }
            }
        }
    }
  ]
)

परिणाम:

{ "utcOffset+04:30" : 0, "utcOffset+05:45" : 15 } 

ऑब्जेक्ट आईडी से मिनट लौटाएं

आप $minute . का उपयोग कर सकते हैं ऑब्जेक्ट आईडी से मिनट का हिस्सा वापस करने के लिए।

ObjectId मान 12 बाइट हेक्साडेसिमल मान होते हैं जिनमें निम्न शामिल होते हैं:

  • ऑब्जेक्ट आईडी के निर्माण का प्रतिनिधित्व करने वाला 4 बाइट टाइमस्टैम्प मान, यूनिक्स युग के बाद से सेकंड में मापा जाता है।
  • 5 बाइट एक यादृच्छिक मान है
  • एक 3 बाइट इंक्रीमेंटिंग काउंटर, एक यादृच्छिक मान के लिए आरंभ किया गया।

संक्षेप में, हमारा दस्तावेज़ इस तरह दिखता है:

{
	"_id" : ObjectId("600631c7c8eb4369cf6ad9c8"),
	"name" : "Fetch",
	"born" : ISODate("2020-12-31T23:30:15.123Z")
}

इस दस्तावेज़ में एक ObjectId है। इसलिए हम $minute . का उपयोग कर सकते हैं उस मिनट को वापस करने के लिए जब हमारा दस्तावेज़ बनाया गया था (या अधिक विशेष रूप से, जब _id फ़ील्ड का ObjectId मान बनाया गया था)।

उदाहरण:

db.pets.aggregate(
  [
    {
      $project:
        {
          "timeStamp": { $toDate: "$_id"},
          "minute": { $minute: "$_id" }
        }
    }
  ]
).pretty()

परिणाम:

{
	"_id" : ObjectId("600631c7c8eb4369cf6ad9c8"),
	"timeStamp" : ISODate("2021-01-19T01:11:35Z"),
	"minute" : 11
}

हम देख सकते हैं कि दस्तावेज़ दिन के पहले घंटे के 11वें मिनट में बनाया गया था।

इस मामले में, मैंने $toDate . का भी उपयोग किया ऑब्जेक्ट आईडी के टाइमस्टैम्प भाग को वापस करने के लिए एकत्रीकरण पाइपलाइन ऑपरेटर।


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB में सभी संग्रह कैसे निर्यात करें?

  2. angular.js के साथ नोटिफिकेशन कैसे पुश करें?

  3. नेवला:सत्यापन त्रुटि पथ आवश्यक है

  4. mongoimport का उपयोग करके दिनांक-डेटाटाइप आयात करना

  5. MongoDB में नेस्टेड सरणियों में तत्व डालें