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

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

SQLite strftime() फ़ंक्शन आपको एक निर्दिष्ट प्रारूप में दिनांक और समय मान वापस करने में सक्षम बनाता है।

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

सिंटैक्स

वाक्य रचना इस प्रकार है:

strftime(format, timestring, modifier, modifier, ...)

format तर्क strftime() . के लिए मान्य प्रारूप स्ट्रिंग प्रतिस्थापन का कोई भी संयोजन हो सकता है समारोह।

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

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

उदाहरण

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

SELECT strftime('%Y-%m-%d %H:%M:%S', 'now');

परिणाम:

2020-04-29 01:29:54

now प्रदान की गई प्रारूप स्ट्रिंग के आधार पर समय स्ट्रिंग को वर्तमान दिनांक और समय में परिवर्तित किया जाता है।

इस मामले में, मेरी प्रारूप स्ट्रिंग बिल्कुल वही परिणाम लौटाती है जो datetime('now') वापस आ जाता।

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

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

SELECT strftime('%Y-%m-%d %H:%M:%S', 'now', '+2 hours');

परिणाम:

2020-04-29 03:31:50

इस मामले में मैंने समय में दो घंटे जोड़े।

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

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

SELECT strftime('%Y-%m-%d %H:%M:%S', 'now', '+2 hours', 'localtime');

परिणाम:

2020-04-29 13:33:22

मेरे मामले में, localtime संशोधक के परिणामस्वरूप समय आगे बढ़ा।

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

आपके स्थानीय समय के आधार पर आपको भिन्न परिणाम मिल सकते हैं।

यहां यह फिर से मूल स्थानीय समय की तुलना संशोधित परिणाम से कर रहा है:

SELECT 
  strftime('%Y-%m-%d %H:%M:%S', 'now', 'localtime') AS "Local",
  strftime('%Y-%m-%d %H:%M:%S', 'now', '+2 hours', 'localtime') AS "Modified";

परिणाम:

Local                Modified           
-------------------  -------------------
2020-04-29 11:34:57  2020-04-29 13:34:57

यूनिक्स/युग काल

आप %s . का उपयोग कर सकते हैं प्रारूप स्ट्रिंग (लोअरकेस) युग समय की गणना करने के लिए।

SELECT strftime('%s', 'now');

परिणाम:

1588124826

युग समय (जिसे युग समय, पॉज़िक्स समय, युग के बाद से सेकंड या UNIX युग समय के रूप में भी जाना जाता है) 1970-01-01 के बाद से सेकंड की संख्या है।

यूनिक्स समय का व्यापक रूप से ऑपरेटिंग सिस्टम और फ़ाइल स्वरूपों में उपयोग किया जाता है।

जूलियन डे

आप %J . का उपयोग कर सकते हैं जूलियन दिवस वापस करने के लिए।

जूलियन दिवस 24 नवंबर, 4714 ईसा पूर्व ग्रीनविच में दोपहर के बाद से दिनों की संख्या है। (प्रोलेप्टिक ग्रेगोरियन कैलेंडर का उपयोग करके)।

यदि प्रोलेप्टिक जूलियन कैलेंडर का उपयोग कर रहे हैं, तो यह सोमवार, 1 जनवरी, 4713 ई.पू. है।

जूलियन दिवस आमतौर पर खगोलविदों, सॉफ़्टवेयर आदि द्वारा दो घटनाओं के बीच बीता हुआ दिनों की गणना करने के लिए उपयोग किया जाता है।

जूलियन दिवस को strftime() . के साथ वापस करने का तरीका यहां दिया गया है समारोह।

SELECT strftime('%J', 'now');

परिणाम:

2458968.575441667               

SQLite में ऐसा करने का दूसरा तरीका julianday() . का उपयोग करना है समारोह।

दिनांक सीमा

जैसा कि सभी SQLite दिनांक और समय कार्यों के साथ होता है, strftime() केवल 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. execSQL () अद्यतन के साथ अद्यतन नहीं होता है

  2. RoomDatabase.Callback() के onCreate () को .build () के सफल कॉल के बाद नहीं बुलाया गया था

  3. यदि टाइमस्टैम्प आज की तारीख से मेल खाता है तो SQLite पंक्तियों का चयन करें

  4. Android में ListView का उपयोग करके SQLite डेटाबेस को कैसे पढ़ें और अपडेट करें?

  5. केवल एक तालिका कैसे बनाएं यदि यह SQLite में मौजूद नहीं है