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

MongoDB $dateFromParts

MongoDB में, $dateFromParts एकत्रीकरण पाइपलाइन ऑपरेटर दिनांक के घटक भागों से दिनांक वस्तु का निर्माण और रिटर्न करता है।

आप प्रत्येक दिनांक भाग को एक अलग फ़ील्ड के रूप में प्रदान करते हैं।

यदि आवश्यक हो तो आप आईएसओ सप्ताह दिनांक प्रारूप में अपने घटक दिनांक फ़ील्ड निर्दिष्ट कर सकते हैं।

उदाहरण

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

{
	"_id" : 1,
	"year" : 2020,
	"month" : 12,
	"day" : 31,
	"hour" : 23,
	"minute" : 30,
	"second" : 25,
	"millisecond" : 123
}

दस्तावेज़ में प्रत्येक दिनांक भाग के लिए एक अलग फ़ील्ड है।

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

db.dateParts.aggregate([
{
   $project: {
      date: {
         $dateFromParts: {
            "year": "$year", 
            "month": "$month", 
            "day": "$day", 
            "hour": "$hour", 
            "minute": "$minute", 
            "second": "$second", 
            "millisecond": "$millisecond"
         }
      }
   }
}])

परिणाम:

{ "_id" : 1, "date" : ISODate("2020-12-31T23:30:25.123Z") }

सभी दिनांक/समय भागों को एक दिनांक वस्तु में बदल दिया गया है।

समय क्षेत्र

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

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

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

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

db.dateParts.aggregate([
{
   $project: {
      dateUTC: {
         $dateFromParts: {
            "year": "$year", 
            "month": "$month", 
            "day": "$day", 
            "hour": "$hour", 
            "minute": "$minute", 
            "second": "$second", 
            "millisecond": "$millisecond",
            "timezone": "Pacific/Auckland"
         }
      },
      dateHonolulu: {
         $dateFromParts: {
            "year": "$year", 
            "month": "$month", 
            "day": "$day", 
            "hour": "$hour", 
            "minute": "$minute", 
            "second": "$second", 
            "millisecond": "$millisecond",
            "timezone": "Pacific/Honolulu"
         }
      },
      dateAuckland: {
         $dateFromParts: {
            "year": "$year", 
            "month": "$month", 
            "day": "$day", 
            "hour": "$hour", 
            "minute": "$minute", 
            "second": "$second", 
            "millisecond": "$millisecond",
            "timezone": "Pacific/Auckland"
         }
      }
   }
}]).pretty()

परिणाम:

{
	"_id" : 1,
	"dateUTC" : ISODate("2020-12-31T10:30:25.123Z"),
	"dateHonolulu" : ISODate("2021-01-01T09:30:25.123Z"),
	"dateAuckland" : ISODate("2020-12-31T10:30:25.123Z")
}

UTC ऑफ़सेट

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

db.dateParts.aggregate([
{
   $project: {
      "date+00:00": {
         $dateFromParts: {
            "year": "$year", 
            "month": "$month", 
            "day": "$day", 
            "hour": "$hour", 
            "minute": "$minute", 
            "second": "$second", 
            "millisecond": "$millisecond",
            "timezone": "+00:00"
         }
      },
      "date-10:00": {
         $dateFromParts: {
            "year": "$year", 
            "month": "$month", 
            "day": "$day", 
            "hour": "$hour", 
            "minute": "$minute", 
            "second": "$second", 
            "millisecond": "$millisecond",
            "timezone": "-10:00"
         }
      },
      "date+12:00": {
         $dateFromParts: {
            "year": "$year", 
            "month": "$month", 
            "day": "$day", 
            "hour": "$hour", 
            "minute": "$minute", 
            "second": "$second", 
            "millisecond": "$millisecond",
            "timezone": "+12:00"
         }
      }
   }
}]).pretty()

परिणाम:

{
	"_id" : 1,
	"date+00:00" : ISODate("2020-12-31T23:30:25.123Z"),
	"date-10:00" : ISODate("2021-01-01T09:30:25.123Z"),
	"date+12:00" : ISODate("2020-12-31T11:30:25.123Z")
}

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

यदि आवश्यक हो तो दिनांक भागों को ISO 8601 प्रारूप का उपयोग करके निर्दिष्ट किया जा सकता है।

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

प्रारूप विनिर्देशक आउटपुट
isoWeekYear ISO 8601 प्रारूप में वर्ष। यदि year . का उपयोग नहीं कर रहे हैं तो यह फ़ील्ड आवश्यक है (और year isoWeekYear . का उपयोग न करने पर आवश्यक है )
isoWeek वर्ष का सप्ताह ISO 8601 प्रारूप में। केवल isoWeekYear . के साथ उपयोग किया जा सकता है ।
isoDayOfWeek सप्ताह का दिन (1-सोमवार, 7-रविवार)। केवल isoWeekYear . के साथ उपयोग किया जा सकता है ।

मान लीजिए हम एक दूसरा दस्तावेज़ सम्मिलित करते हैं जो इस तरह दिखता है:

{
	"_id" : 2,
	"isoWeekYear" : 2021,
	"isoWeek" : 32,
	"isoDayOfWeek" : 7,
	"hour" : 23,
	"minute" : 30,
	"second" : 25,
	"millisecond" : 123,
	"timezone" : "UTC"
}

हम देख सकते हैं कि यह isoWeekYear . का उपयोग करता है , isoWeek , और isoDayOfWeek year . के बजाय , month , और day (जो पहला दस्तावेज़ उपयोग करता है)।

हम इस दस्तावेज़ से दिनांक वस्तु बनाने के लिए निम्नलिखित कोड का उपयोग कर सकते हैं:

db.dateParts.aggregate([
  { $match: { _id: 2} },
  {
    $project: {
        date: {
          $dateFromParts: {
              "isoWeekYear": "$isoWeekYear", 
              "isoWeek": "$isoWeek", 
              "isoDayOfWeek": "$isoDayOfWeek", 
              "hour": "$hour", 
              "minute": "$minute", 
              "second": "$second", 
              "millisecond": "$millisecond", 
              "timezone": "$timezone"
          }
        }
    }
  }
])

परिणाम:

{ "_id" : 2, "date" : ISODate("2021-08-15T23:30:25.123Z") } 

सीमा क्षेत्र से बाहर

MongoDB 4.4 में प्रारंभ, year . के लिए समर्थित मान श्रेणी और isoWeekYear है 1-9999 . पिछले संस्करणों में, इन मानों के लिए निचली सीमा 0 . थी और समर्थित मान श्रेणी 0-9999 . थी ।

MongoDB 4.0 में प्रारंभ, यदि year . के अलावा अन्य फ़ील्ड के लिए निर्दिष्ट मान , isoWeekYear , और timezone मान्य सीमा से बाहर है, $dateFromParts दिनांक की गणना करने के लिए ऑपरेटर अन्य दिनांक भागों से अंतर को वहन या घटाता है।

मान सीमा से अधिक है

मान लीजिए हम अपने संग्रह में निम्नलिखित दस्तावेज़ जोड़ते हैं:

{
	"_id" : 3,
	"year" : 2020,
	"month" : 14,
	"day" : 65,
	"hour" : 48,
	"minute" : 130,
	"second" : 625,
	"millisecond" : 123
}

इस दस्तावेज़ में कई दिनांक और समय फ़ील्ड उनकी संबंधित मान्य सीमाओं से अधिक हैं।

आइए इसे डेट ऑब्जेक्ट में बदलने के लिए निम्न कमांड चलाएँ:

db.dateParts.aggregate([
  { $match: { _id: 3} },
  {
    $project: {
        date: {
          $dateFromParts: {
              "year": "$year", 
              "month": "$month", 
              "day": "$day", 
              "hour": "$hour", 
              "minute": "$minute", 
              "second": "$second", 
              "millisecond": "$millisecond"
          }
        }
    }
  }
])

परिणाम:

{ "_id" : 3, "date" : ISODate("2021-04-08T02:20:25.123Z") }

हम देख सकते हैं कि परिणामी दिनांक वस्तु में दिनांक भाग दस्तावेज़ में उनके संबंधित दिनांक भागों से भिन्न हैं। ऐसा इसलिए है क्योंकि $dateFromParts दिनांक भाग मानों के लिए खाते की तिथि की पुनर्गणना की गई जो उनकी सामान्य सीमा से अधिक थी।

मान सीमा से कम

मान लीजिए हम अपने संग्रह में निम्नलिखित दस्तावेज़ जोड़ते हैं:

{
	"_id" : 4,
	"year" : 2020,
	"month" : 0,
	"day" : 0,
	"hour" : 0,
	"minute" : 0,
	"second" : 0,
	"millisecond" : 0
}

इस दस्तावेज़ में कई दिनांक और समय फ़ील्ड उनकी संबंधित मान्य सीमाओं से कम हैं।

आइए इसे डेट ऑब्जेक्ट में बदलने के लिए निम्न कमांड चलाएँ:

db.dateParts.aggregate([
  { $match: { _id: 4} },
  {
    $project: {
        date: {
          $dateFromParts: {
              "year": "$year", 
              "month": "$month", 
              "day": "$day", 
              "hour": "$hour", 
              "minute": "$minute", 
              "second": "$second", 
              "millisecond": "$millisecond"
          }
        }
    }
  }
])

परिणाम:

{ "_id" : 4, "date" : ISODate("2019-11-30T00:00:00Z") }

  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. mongodb php - कैसे करें INNER JOIN-like query

  2. एसएनएमपी के साथ क्लस्टर कंट्रोल को एकीकृत करना:भाग दो

  3. त्रुटि:getaddrinfo ENOTFOUND नोडज में कॉल पाने के लिए

  4. MongoDB - सभी वस्तुओं को लूप किए बिना जावा में संग्रह की प्रतिलिपि बनाएँ

  5. MongoDB में कस्टम ऑब्जेक्ट आईडी बनाना