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

MongoDB में एक तिथि से दिन प्राप्त करने के 8 तरीके

किसी तिथि से दिन निकालते समय, हम जिस सटीक विकल्प का उपयोग करते हैं, वह इस बात पर निर्भर करेगा कि हम उस दिन को किस प्रकार प्रदर्शित करना चाहते हैं।

उदाहरण के लिए, क्या हम सप्ताह का दिन, महीने का दिन या वर्ष का दिन चाहते हैं? या शायद हम इसे आईएसओ 8601 प्रारूप में चाहते हैं? हम जो चुनते हैं उसके आधार पर वापसी मूल्य आमतौर पर भिन्न होगा।

यह लेख उन विकल्पों की पड़ताल करता है, और इसलिए MongoDB में किसी तिथि से दिन के हिस्से को वापस करने के 8 तरीके प्रस्तुत करता है।

नमूना डेटा

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

{ "_id" : 1, "name" : "Scratch", "born" : ISODate("2021-01-03T23:30:15.123Z") }
{ "_id" : 2, "name" : "Meow", "born" : ISODate("2019-12-08T04:00:12Z") }
{ "_id" : 3, "name" : "Fluffy", "born" : ISODate("2020-09-24T10:30:00Z") }

निम्नलिखित उदाहरण born . से दिन के हिस्से को वापस करने के लिए विभिन्न विकल्पों को प्रदर्शित करते हैं उन दस्तावेज़ों का क्षेत्र।

$dayOfWeek संचालिका

जैसा कि नाम से ही स्पष्ट है, $dayOfWeek ऑपरेटर एक तारीख से सप्ताह का दिन लौटाता है।

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

db.cats.aggregate(
  [
    {
      $project:
        {
          _id: 0,
          birthDayOfWeek: { $dayOfWeek: "$born" }
        }
    }
  ]
)

परिणाम:

{ "birthDayOfWeek" : 1 }
{ "birthDayOfWeek" : 1 }
{ "birthDayOfWeek" : 5 }

$dayOfWeek . का उपयोग करते समय समय क्षेत्र निर्दिष्ट करना भी संभव है ऑपरेटर।

MongoDB देखें $dayOfWeek अधिक जानकारी और उदाहरणों के लिए।

$dayOfMonth संचालिका

$dayOfMonth ऑपरेटर एक तारीख से महीने का दिन लौटाता है।

उदाहरण:

db.cats.aggregate(
  [
    {
      $project:
        {
          _id: 0,
          birthDayOfMonth: { $dayOfMonth: "$born" }
        }
    }
  ]
)

परिणाम:

{ "birthDayOfMonth" : 3 }
{ "birthDayOfMonth" : 8 }
{ "birthDayOfMonth" : 24 }

$dayOfMonth . का उपयोग करते समय आप समय क्षेत्र भी निर्दिष्ट कर सकते हैं ऑपरेटर।

MongoDB देखें $dayOfMonth अधिक जानकारी और उदाहरणों के लिए।

$dayOfYear संचालिका

हाँ, आपने अनुमान लगाया। $dayOfYear ऑपरेटर एक तारीख से वर्ष का दिन लौटाता है।

उदाहरण:

db.cats.aggregate(
  [
    {
      $project:
        {
          _id: 0,
          birthDayOfYear: { $dayOfYear: "$born" }
        }
    }
  ]
)

परिणाम:

{ "birthDayOfYear" : 3 }
{ "birthDayOfYear" : 342 }
{ "birthDayOfYear" : 268 }

$dayOfYear ऑपरेटर एक टाइमज़ोन पैरामीटर भी स्वीकार करता है।

MongoDB देखें $dayOfYear अधिक जानकारी और उदाहरणों के लिए।

$dateToString संचालिका

$dateToString ऑपरेटर उपयोगकर्ता द्वारा निर्दिष्ट प्रारूप के अनुसार दिनांक ऑब्जेक्ट को स्ट्रिंग में परिवर्तित करता है। इसलिए उपयोगकर्ता निर्दिष्ट कर सकता है कि यदि आवश्यक हो तो केवल दिन का हिस्सा लौटाया जाता है।

प्रत्येक दिनांक भाग के लिए प्रारूप विनिर्देशक हैं, और जब दिन भाग की बात आती है, तो आपके पास प्रारूप विनिर्देशक का एक विकल्प होता है जो इस बात पर निर्भर करेगा कि आप सप्ताह का दिन, महीने का दिन, वर्ष का दिन, या सप्ताह का दिन आईएसओ 8601 प्रारूप में।

उदाहरण:

db.cats.aggregate(
   [
     {
       $project: {
         _id: 0,
          birthDayOfWeek: { $dateToString: { format: "%w", date: "$born" } },
          birthDayOfMonth: { $dateToString: { format: "%d", date: "$born" } },
          birthDayOfYear: { $dateToString: { format: "%j", date: "$born" } },
          birthDayOfWeekISO: { $dateToString: { format: "%u", date: "$born" } }
       }
     }
   ]
).pretty()

परिणाम:

{
	"birthDayOfWeek" : "1",
	"birthDayOfMonth" : "03",
	"birthDayOfYear" : "003",
	"birthDayOfWeekISO" : "7"
}
{
	"birthDayOfWeek" : "1",
	"birthDayOfMonth" : "08",
	"birthDayOfYear" : "342",
	"birthDayOfWeekISO" : "7"
}
{
	"birthDayOfWeek" : "5",
	"birthDayOfMonth" : "24",
	"birthDayOfYear" : "268",
	"birthDayOfWeekISO" : "4"
}

हम परिणाम में अन्य दिनांक भागों को शामिल करने के लिए अधिक प्रारूप विनिर्देशक प्रदान कर सकते थे, लेकिन यह देखते हुए कि हम केवल इस लेख में दिन निकालने में रुचि रखते हैं, हमने केवल दिन के हिस्से को वापस करने के लिए प्रारूप विनिर्देशक का उपयोग किया।

MongoDB देखें $dateToString अधिक जानकारी और उदाहरणों के लिए।

MongoDB $dateToString भी देखें प्रारूप विनिर्देशकों की सूची के लिए प्रारूप विनिर्देशक जिनका उपयोग आप $dateToString के साथ कर सकते हैं ।

$dateToParts संचालिका

$dateToParts ऑपरेटर एक दस्तावेज़ देता है जिसमें किसी दिए गए बीएसओएन दिनांक मान के घटक भाग अलग-अलग गुणों के रूप में होते हैं। लौटाए गए गुण year हैं , month , day , hour , minute , second और millisecond

इसलिए हम $dateToParts . का उपयोग कर सकते हैं एक पाइपलाइन चरण में, फिर दूसरा पाइपलाइन चरण जोड़ें जो day . को निकालता है यदि आवश्यक हो तो भाग।

यहाँ क्या है $dateToParts हमारे तीन दस्तावेज़ों के लिए रिटर्न:

db.cats.aggregate(
  [
    {
      $project:
        {
          _id: 0,
          dateParts: { $dateToParts: { date: "$born" } }
        }
    }
  ]
).pretty()

परिणाम:

{
	"dateParts" : {
		"year" : 2021,
		"month" : 1,
		"day" : 3,
		"hour" : 23,
		"minute" : 30,
		"second" : 15,
		"millisecond" : 123
	}
}
{
	"dateParts" : {
		"year" : 2019,
		"month" : 12,
		"day" : 8,
		"hour" : 4,
		"minute" : 0,
		"second" : 12,
		"millisecond" : 0
	}
}
{
	"dateParts" : {
		"year" : 2020,
		"month" : 9,
		"day" : 24,
		"hour" : 10,
		"minute" : 30,
		"second" : 0,
		"millisecond" : 0
	}
}

इस डेटा को केवल day . निकालने के लिए पाइपलाइन के अगले चरण में भेजा जा सकता है फ़ील्ड.

अगर हम केवल day . के लिए एक और प्रक्षेपण जोड़ते हैं तो यहां क्या होता है फ़ील्ड:

db.cats.aggregate(
  [
    {
      $project:
        {
          _id: 0,
          dateParts: { $dateToParts: { date: "$born" } }
        }
    },
    {
      $project:
        {
          birthDay: "$dateParts.day"
        }
    }
  ]
)

परिणाम:

{ "birthDay" : 3 }
{ "birthDay" : 8 }
{ "birthDay" : 24 }

यह स्पष्ट रूप से पिछले विकल्पों का उपयोग करने जैसा संक्षिप्त नहीं है। हालांकि, आप अपनी पाइपलाइन में क्या कर रहे हैं, इस पर निर्भर करते हुए, यह दृष्टिकोण एक विकल्प हो सकता है।

यह भी उल्लेखनीय है कि $dateToParts एक iso8601 स्वीकार करता है पैरामीटर, जो आउटपुट दस्तावेज़ को ISO सप्ताह दिनांक फ़ील्ड का उपयोग करने के लिए संशोधित करता है।

MongoDB देखें $dateToParts अधिक जानकारी और उदाहरणों के लिए।

forEach() विधि

आप cursor.forEach() . का उपयोग कर सकते हैं कर्सर के माध्यम से पुनरावृति करने के लिए, केवल दिन का मान वापस करने के लिए JavaScript पद्धति का उपयोग करना।

db.cats.find().forEach(
  function(c) {
    print(
      c.born.getDay()
      );
  }
);

परिणाम:

1
0
4

इस मामले में, हम जावास्क्रिप्ट का उपयोग करते हैं getDay() विधि, जो स्थानीय समय के अनुसार, दी गई तिथि के लिए सप्ताह के दिन के अनुरूप 0 और 6 के बीच एक पूर्णांक संख्या लौटाती है।

एक अन्य विकल्प getUTCDay() . का उपयोग करना है विधि, जो सार्वभौमिक समय का उपयोग करती है। हम अगले उदाहरण में इस पद्धति का उपयोग करेंगे।

वैकल्पिक रूप से, हम जावास्क्रिप्ट का उपयोग कर सकते थे getDate() विधि, जो 1 और 31 के बीच एक पूर्णांक संख्या लौटाती है, जो दी गई तारीख के लिए महीने के दिन का प्रतिनिधित्व करती है।

साथ ही, यह विकल्प केवल वास्तविक दिन का मान देता है, न कि संपूर्ण दस्तावेज़, जैसे पिछले उदाहरणों में।

map() विधि

cursor.map() विधि कर्सर द्वारा देखे गए प्रत्येक दस्तावेज़ पर एक फ़ंक्शन लागू करती है और मानों को एक सरणी में जोड़ती है।

उदाहरण:

db.cats.find().map(
  function(c) {
    c = c.born.getUTCDay();
    return c;
  }
);

परिणाम:

[ 0, 0, 4 ]

जैसा कि उल्लेख किया गया है, जावास्क्रिप्ट getUTCDay() विधि सार्वभौमिक समय का उपयोग करके अपना परिणाम लौटाती है। इस मामले में, इसके परिणामस्वरूप पहले दस्तावेज़ के लिए एक अलग मान लौटाया गया (हमें 0 . मिला इस उदाहरण में, बनाम 1 पिछले एक में)।

$isoDayOfWeek संचालिका

यदि आपको सप्ताह के दिन को ISO 8601 प्रारूप में वापस करना है, तो आप $isoDayOfWeek का उपयोग कर सकते हैं . ISO 8601 वर्ष 1 सप्ताह के सोमवार से शुरू होता है और अंतिम सप्ताह के रविवार को समाप्त होता है।

उदाहरण:

db.cats.aggregate(
  [
    {
      $project:
        {
          _id: 0,
          birthIsoDayOfWeek: { $isoDayOfWeek: "$born" }
        }
    }
  ]
)

परिणाम:

{ "birthIsoDayOfWeek" : 7 }
{ "birthIsoDayOfWeek" : 7 }
{ "birthIsoDayOfWeek" : 4 }

इस मामले में हमें $dayOfWeek . का उपयोग करते समय मिले परिणाम से बिल्कुल अलग परिणाम मिलता है ऑपरेटर, जिस तरह से आईएसओ 8601 तारीखों की गणना करता है।

यहां एक उदाहरण दिया गया है जो इस अंतर को प्रदर्शित करता है:

db.cats.aggregate(
  [
    {
      $project:
        {
          _id: 0,
          birthDayOfWeek: { $dayOfWeek: "$born" },
          birthIsoDayOfWeek: { $isoDayOfWeek: "$born" }
        }
    }
  ]
)

परिणाम:

{ "birthDayOfWeek" : 1, "birthIsoDayOfWeek" : 7 }
{ "birthDayOfWeek" : 1, "birthIsoDayOfWeek" : 7 }
{ "birthDayOfWeek" : 5, "birthIsoDayOfWeek" : 4 }

  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. GridFS, एक्सप्रेस, mongoDB, node.js . में POST अनुरोध से डेटा स्ट्रीम संग्रहीत करना

  2. एक मोंगोडब दस्तावेज़ के औसत मूल्य की गणना करें

  3. मोंगोडीबी $जोड़ें

  4. आवेदन में आग लगने वाले सभी प्रश्नों को लॉग करें

  5. शुरुआती के लिए MongoDB ट्यूटोरियल (पूरी गाइड) - 15 मिनट में MongoDB सीखें