SQLite
 sql >> डेटाबेस >  >> RDS >> SQLite

SQLite में दिनांक () फ़ंक्शन कैसे काम करता है

SQLite में एक date() होती है फ़ंक्शन जो आपको समय स्ट्रिंग और किसी भी संशोधक के आधार पर दिनांक मान वापस करने में सक्षम बनाता है।

यह इस प्रारूप में दिनांक लौटाता है:YYYY-MM-DD

इस फ़ंक्शन का उपयोग करने के लिए, आपको एक समय स्ट्रिंग, साथ ही कोई भी (वैकल्पिक) संशोधक प्रदान करने की आवश्यकता है। एक संशोधक आपको दिनांक बदलने की अनुमति देता है, जैसे कि कई दिन जोड़ना, इसे स्थानीय समय पर सेट करना, आदि

सिंटैक्स

date() . का सिंटैक्स फ़ंक्शन इस प्रकार है:

date(timestring, modifier, modifier, ...)

timestring तर्क एक मान्य समय स्ट्रिंग होना चाहिए।

modifier तर्क वैकल्पिक हैं। आप एक या अधिक संशोधक प्रदान कर सकते हैं। यदि आप एक संशोधक प्रदान करते हैं, तो यह एक मान्य संशोधक होना चाहिए।

उदाहरण

date() को प्रदर्शित करने के लिए यहां एक उदाहरण दिया गया है फ़ंक्शन का उपयोग एक तर्क के साथ किया जा रहा है।

SELECT date('now');

परिणाम:

2020-04-27

now टाइम स्ट्रिंग को वर्तमान दिनांक और समय में बदल दिया जाता है। यह देखते हुए कि मैं date() . का उपयोग कर रहा हूं समारोह, केवल तारीख लौटा दी जाती है।

एक संशोधक जोड़ें

हम एक संशोधक का उपयोग करके पिछले परिणाम को संशोधित कर सकते हैं। यहाँ एक उदाहरण है।

SELECT date('now', '+6 months');

परिणाम:

2020-10-27

इस मामले में, मैंने तारीख में छह महीने जोड़े हैं।

एकाधिक संशोधक

जैसा कि बताया गया है, आप एक या अधिक संशोधक जोड़ सकते हैं। पिछले उदाहरण में एक और संशोधक जोड़ने का एक उदाहरण यहां दिया गया है।

SELECT date('now', '+6 months', 'localtime');

परिणाम:

2020-10-28

मेरे मामले में, localtime संशोधक के परिणामस्वरूप दिनांक में एक दिन जोड़ा गया।

ऐसा करने का कारण यह है कि localtime संशोधक मानता है कि प्रदान की गई समय स्ट्रिंग यूनिवर्सल कोऑर्डिनेटेड टाइम (UTC) में है। इसके बाद यह समय स्ट्रिंग को समायोजित करता है ताकि यह स्थानीय समय प्रदर्शित करे।

इसलिए, आपके स्थानीय समय के आधार पर आपको एक अलग परिणाम मिल सकता है।

समय स्ट्रिंग के रूप में शाब्दिक स्ट्रिंग

ऊपर दिए गए उदाहरणों में now का इस्तेमाल किया गया है समय स्ट्रिंग के रूप में, लेकिन आप कोई भी मान्य समय स्ट्रिंग प्रदान कर सकते हैं।

यहां कुछ अन्य उदाहरण दिए गए हैं।

SELECT date('2020-04-27 23:58:57');

परिणाम:

2020-04-27 

इस मामले में यह केवल तिथि से समय भाग को हटा देता है।

यहाँ यह फिर से है, लेकिन कुछ संशोधक के साथ।

SELECT date('2020-04-27 23:58:57', 'start of year', '+6 months');

परिणाम:

2020-07-01 

इस मामले में मैं उस तारीख को प्राप्त करना चाहता था जो प्रदान की गई तारीख के वर्ष की शुरुआत से 6 महीने है।

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

SELECT date('2458967.49737293');

परिणाम:

2020-04-27

तारीख() बनाम strftime()

date() फ़ंक्शन बिल्कुल वही परिणाम देता है जो strftime('%Y-%m-%d', ...) रिटर्न। date() फ़ंक्शन इसे करने का एक अधिक सुविधाजनक तरीका है।

SELECT 
  date('now'),
  strftime('%Y-%m-%d', 'now');

परिणाम:

date('now')  strftime('%Y-%m-%d', 'now')
-----------  ---------------------------
2020-04-28   2020-04-28                 

दिनांक सीमा

जैसा कि सभी SQLite दिनांक और समय कार्यों के साथ होता है, date() केवल 0000-01-01 00:00:00 और 9999-12-31 23:59:59 (जूलियन दिन संख्या 1721059.5 से 5373484.5) के बीच की तिथियों के लिए काम करता है।

उस सीमा से बाहर की तारीखों के लिए, परिणाम अपरिभाषित होते हैं।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. sqlite DB से तालिका का नाम कैसे सूचीबद्ध करें - Android

  2. SQLite में यूनिक्स टाइमस्टैम्प वापस करने के 2 तरीके

  3. SQLite JSON_REPLACE ()

  4. उपयोगकर्ताओं को मेरे सामग्री प्रदाता में केवल कुछ तालिकाओं तक पहुंचने की अनुमति दें

  5. SQLite जाँच की कमी