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

मोंगोडीबी $dateToString

MongoDB में, $dateToString एकत्रीकरण पाइपलाइन ऑपरेटर किसी दिए गए दिनांक ऑब्जेक्ट को एक स्ट्रिंग में कनवर्ट करता है।

$dateToString ऑपरेटर या तो दिनांक, टाइमस्टैम्प, या ऑब्जेक्ट आईडी स्वीकार करता है।

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

प्रारूप विनिर्देश MongoDB संस्करण 4.0 से वैकल्पिक है, जब featureCompatibilityVersion 4.0 . पर सेट है या उच्चतर। पहले के संस्करणों को प्रारूप विनिर्देश की आवश्यकता होती है।

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

आप onNull . का भी उपयोग कर सकते हैं यह निर्दिष्ट करने के लिए पैरामीटर कि यदि दिनांक null है तो क्या लौटाया जाए या गायब है।

उदाहरण

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

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

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

db.pets.aggregate(
   [
     {
       $project: {
         _id: 0,
          dateString: { $dateToString: { format: "%Y-%m-%dT%H:%M:%S.%LZ", date: "$born" } }
       }
     }
   ]
)

परिणाम:

{ "dateString" : "2020-12-31T23:30:15.123Z" }

यह उदाहरण %Y-%m-%dT%H:%M:%S.%LZ का उपयोग करता है प्रारूप विनिर्देश के रूप में। यह डिफ़ॉल्ट प्रारूप विनिर्देश होता है, लेकिन इस मामले में हमने इसे स्पष्ट रूप से निर्दिष्ट किया है। हम देख सकते हैं कि निर्दिष्ट प्रारूप का उपयोग करके दिनांक स्ट्रिंग लौटा दी गई है।

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

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

MongoDB देखें $dateToString प्रारूप विनिर्देशकों की सूची के लिए प्रारूप विनिर्देशक उपलब्ध हैं।

डिफ़ॉल्ट आउटपुट

जैसा कि उल्लेख किया गया है, पिछले उदाहरण में प्रारूप विनिर्देश डिफ़ॉल्ट प्रारूप विनिर्देश है।

यदि आप featureCompatibilityVersion के साथ MongoDB संस्करण 4.0 या इसके बाद के संस्करण का उपयोग कर रहे हैं 4.0 . पर सेट करें या उच्चतर (अपना वर्तमान featureCompatibilityVersion देखने का तरीका देखें) और इसे कैसे सेट करें), यदि आप उपरोक्त प्रारूप का उपयोग करके दिनांक को प्रारूपित करना चाहते हैं, तो आप प्रारूप विनिर्देश को छोड़ सकते हैं।

इसलिए, हम पिछले को फिर से लिख सकते हैं। इसका उदाहरण:

db.pets.aggregate(
   [
     {
       $project: {
         _id: 0,
          dateString: { $dateToString: { date: "$born" } }
       }
     }
   ]
)

परिणाम:

{ "dateString" : "2020-12-31T23:30:15.123Z" }

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

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

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

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

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

db.pets.aggregate(
   [
     {
       $project: {
         _id: 0,
          UTC: { $dateToString: { format: "%Y-%m-%dT%H:%M", date: "$born", timezone: "UTC" } },
          Honolulu: { $dateToString: { format: "%Y-%m-%dT%H:%M", date: "$born", timezone: "Pacific/Honolulu" } },
          Auckland: { $dateToString: { format: "%Y-%m-%dT%H:%M", date: "$born", timezone: "Pacific/Auckland" } }
       }
     }
   ]
).pretty()

परिणाम:

{
	"UTC" : "2020-12-31T23:30",
	"Honolulu" : "2020-12-31T13:30",
	"Auckland" : "2021-01-01T12:30"
}

UTC ऑफ़सेट

यहां एक उदाहरण दिया गया है जो यूटीसी ऑफ़सेट का उपयोग करता है।

db.pets.aggregate(
   [
     {
       $project: {
         _id: 0,
          UTC: { $dateToString: { format: "%Y-%m-%dT%H:%M", date: "$born", timezone: "+00:00" } },
          Honolulu: { $dateToString: { format: "%Y-%m-%dT%H:%M", date: "$born", timezone: "-10:00" } },
          Auckland: { $dateToString: { format: "%Y-%m-%dT%H:%M", date: "$born", timezone: "+12:00" } }
       }
     }
   ]
).pretty()

परिणाम:

{
	"UTC" : "2020-12-31T23:30",
	"Honolulu" : "2020-12-31T13:30",
	"Auckland" : "2021-01-01T11:30"
}

ISO सप्ताह दिनांक प्रारूप

कुछ प्रारूप विनिर्देशक हैं जो आपको आईएसओ 8601 प्रारूप का उपयोग करके दिनांक स्ट्रिंग को आउटपुट करने में सक्षम बनाते हैं।

विशेष रूप से, आप इसका उपयोग कर सकते हैं:

प्रारूप विनिर्देशक आउटपुट
%G ISO 8601 प्रारूप में वर्ष
%u आईएसओ 8601 प्रारूप में सप्ताह का दिन संख्या (1-सोमवार, 7-रविवार)
%V वर्ष का सप्ताह ISO 8601 प्रारूप में

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

{
	"_id" : ObjectId("6008c9a5c8eb4369cf6ad9cc"),
	"name" : "Scratch",
	"born" : ISODate("2021-01-03T23:30:15.123Z")
}

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

प्रदर्शित करने के लिए यहां एक उदाहरण दिया गया है:

db.cats.aggregate(
   [
     {
       $project: {
         _id: 0,
          isoYear: { $dateToString: { format: "%G", date: "$born" } },
          isoDayOfWeek: { $dateToString: { format: "%u", date: "$born" } },
          isoWeekOfYear: { $dateToString: { format: "%V", date: "$born" } }
       }
     }
   ]
)

परिणाम:

{ "isoYear" : "2020", "isoDayOfWeek" : "7", "isoWeekOfYear" : "53" }

इसके विपरीत, नीचे वही उदाहरण दिया गया है, लेकिन गैर-आईएसओ सप्ताह दिनांक भागों का उपयोग किया जा रहा है।

db.cats.aggregate(
   [
     {
       $project: {
         _id: 0,
          year: { $dateToString: { format: "%Y", date: "$born" } },
          dayofweek: { $dateToString: { format: "%w", date: "$born" } },
          weekofyear: { $dateToString: { format: "%U", date: "$born" } }
       }
     }
   ]
)

परिणाम:

{ "year" : "2021", "dayofweek" : "1", "weekofyear" : "01" }

हम देख सकते हैं कि परिणाम पूरी तरह से अलग है।

onNull पैरामीटर

onNull पैरामीटर का उपयोग यह निर्दिष्ट करने के लिए किया जा सकता है कि यदि दिनांक शून्य है या मौजूद नहीं है तो क्या लौटाया जाए।

onNull . को प्रदान किया गया मान पैरामीटर कोई भी मान्य व्यंजक हो सकता है।

यहां एक उदाहरण दिया गया है:

db.pets.aggregate(
   [
     {
       $project: {
          _id: 0,
          dateString: { $dateToString: { date: null, onNull: "No date supplied" } }
       }
     }
   ]
)

परिणाम:

{ "dateString" : "No date supplied" }

इस मामले में, तारीख null थी और इसलिए आउटपुट दस्तावेज़ में वह स्ट्रिंग शामिल है जो मैंने onNull . के लिए प्रदान की थी पैरामीटर।

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

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

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

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

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

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

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

उदाहरण:

db.pets.aggregate(
   [
     {
       $project: {
          timestamp: { $toDate: "$_id" },
          dateString: { $dateToString: { format: "%d-%m-%Y", date: "$_id" } }
       }
     }
   ]
).pretty()

परिणाम:

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

इस मामले में, मैंने केवल दिनांक भाग (समय भाग नहीं) वापस करने का निर्णय लिया। मैंने यह प्रदर्शित करने के लिए दिनों, महीनों और वर्ष के क्रम को भी बदल दिया है कि यदि आवश्यक हो तो आप निश्चित रूप से ऐसा कर सकते हैं।

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


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. मोंगो क्वेरी प्रश्न $gt,$lt

  2. स्प्रिंग डेटा मोंगो - एम्बेडेड दस्तावेज़ में अद्वितीय संयोजन फ़ील्ड लागू करें

  3. स्व-होस्टेड MongoDB

  4. Mongoose (या MongoDB) में एक TransientTransactionError क्या है?

  5. नेवला:गहरी आबादी (आबादी वाले क्षेत्र में आबाद)