PL / SQL - दिनांक और समय

इस अध्याय में, हम PL / SQL में दिनांक और समय पर चर्चा करेंगे। पीएल / एसक्यूएल में दिनांक और समय से संबंधित डेटा प्रकार के दो वर्ग हैं -

  • डेटाटाइम प्रकार
  • अंतराल डेटा प्रकार

डेटाटाइम डेटा प्रकार हैं -

  • DATE
  • TIMESTAMP
  • टाइम ज़ोन के साथ टाइमस्टैम्प
  • स्थानीय समय क्षेत्र के साथ समय

अंतराल डेटा प्रकार हैं -

  • अंतरजातीय महीने के लिए
  • इंटरएक्टिव दिन के बाद

डेटाटाइम और अंतराल डेटा प्रकारों के लिए फ़ील्ड मान

दोनों datetime तथा interval डेटा प्रकारों से मिलकर बनता है fields। इन फ़ील्ड्स के मान डेटा प्रकार का मान निर्धारित करते हैं। निम्न तालिका डेटासेट और अंतराल के लिए फ़ील्ड और उनके संभावित मानों को सूचीबद्ध करती है।

कार्यक्षेत्र नाम मान्य डेटाटाइम मान वैध अंतराल मान
साल -4712 से 9999 (वर्ष 0 को छोड़कर) कोई भी नॉनजरो पूर्णांक
महीना 01 से 12 0 से 11
दिन 01 से 31 (स्थानीय लोगों के लिए कैलेंडर के नियमों के अनुसार MONTH और YEAR के मूल्यों तक सीमित) कोई भी नॉनजरो पूर्णांक
इस घंटे 00 से 23 तक 0 से 23
मिनट 00 से 59 0 से 59
दूसरा

00 से 59.9 (एन), जहां 9 (एन) समय आंशिक सेकंड की सटीकता है

9 (n) भाग DATE के लिए लागू नहीं है।

0 से 59.9 (एन), जहां 9 (एन) अंतराल के आंशिक सेकंड की सटीकता है
TIMEZONE_HOUR

-12 से 14 (दिन की बचत समय परिवर्तन को समायोजित करता है)

DATE या TIMESTAMP के लिए लागू नहीं है।

लागू नहीं
TIMEZONE_MINUTE

00 से 59

DATE या TIMESTAMP के लिए लागू नहीं है।

लागू नहीं
TIMEZONE_REGION DATE या TIMESTAMP के लिए लागू नहीं है। लागू नहीं
TIMEZONE_ABBR DATE या TIMESTAMP के लिए लागू नहीं है। लागू नहीं

डेटाटाइम प्रकार और कार्य

निम्नलिखित डेटा प्रकार हैं:

दिनांक

यह तिथि और समय की जानकारी को चरित्र और संख्या डेटाटिप्स दोनों में संग्रहीत करता है। यह शताब्दी, वर्ष, माह, तिथि, घंटे, मिनट और दूसरे पर जानकारी से बना है। यह इस प्रकार है -

TIMESTAMP

यह DATE डेटा प्रकार का एक एक्सटेंशन है। यह DATE डेटाटाइप का वर्ष, महीना और दिन संग्रहीत करता है, साथ ही घंटे, मिनट और दूसरे मान। यह सटीक समय मूल्यों को संग्रहीत करने के लिए उपयोगी है।

टाइम ज़ोन के साथ टाइमस्टैम्प

यह TIMESTAMP का एक प्रकार है जिसमें एक समय क्षेत्र क्षेत्र का नाम या इसके मान में एक समय क्षेत्र ऑफसेट शामिल है। समय क्षेत्र ऑफसेट स्थानीय समय और UTC के बीच अंतर (घंटे और मिनट में) है। यह डेटा प्रकार भौगोलिक क्षेत्रों में तारीख की जानकारी एकत्र करने और मूल्यांकन करने के लिए उपयोगी है।

स्थानीय समय क्षेत्र के साथ समय

यह TIMESTAMP का दूसरा संस्करण है जिसमें इसके मूल्य में एक समय क्षेत्र ऑफसेट शामिल है।

निम्नलिखित तालिका डेटाटाइम फ़ंक्शन प्रदान करती है (जहां, x का डेटटाइम मान है) -

S.No समारोह का नाम और विवरण
1

ADD_MONTHS(x, y);

जोड़ता y महीनों से x

2

LAST_DAY(x);

महीने का आखिरी दिन लौटाता है।

3

MONTHS_BETWEEN(x, y);

के बीच महीनों की संख्या देता है x तथा y

4

NEXT_DAY(x, day);

अगले की दिनांक रिटर्न दिन के बादx

5

NEW_TIME;

उपयोगकर्ता द्वारा निर्दिष्ट टाइम ज़ोन से समय / दिन का मान लौटाता है।

6

ROUND(x [, unit]);

राउंड x

7

SYSDATE();

वर्तमान डेटाटाइम लौटाता है।

8

TRUNC(x [, unit]);

ट्रंकेटस x

टाइमस्टैम्प फ़ंक्शन (जहां, x का टाइमस्टैम्प मान है) -

S.No समारोह का नाम और विवरण
1

CURRENT_TIMESTAMP();

सत्र समय क्षेत्र के साथ वर्तमान सत्र समय वाले टाइम ज़ोन के साथ एक टाइमस्टैम्प लौटाता है।

2

EXTRACT({ YEAR | MONTH | DAY | HOUR | MINUTE | SECOND } | { TIMEZONE_HOUR | TIMEZONE_MINUTE } | { TIMEZONE_REGION | } TIMEZONE_ABBR ) FROM x)

एक वर्ष, महीना, दिन, घंटा, मिनट, दूसरा या समय क्षेत्र से अर्क और रिटर्न x

3

FROM_TZ(x, time_zone);

TIMESTAMP x और टाइम ज़ोन द्वारा निर्दिष्ट टाइम ज़ोन को TIMESTAMP TIMEZONE के साथ परिवर्तित करता है।

4

LOCALTIMESTAMP();

सत्र समय क्षेत्र में स्थानीय समय वाले TIMESTAMP को लौटाता है।

5

SYSTIMESTAMP();

डेटाबेस समय क्षेत्र के साथ वर्तमान डेटाबेस समय के साथ समय क्षेत्र के साथ एक समय रिटर्न देता है।

6

SYS_EXTRACT_UTC(x);

UTC में दिनांक और समय वाले TIMESTAMP को TIMEZONE x के साथ टाइमस्टैम्प में कनवर्ट करता है।

7

TO_TIMESTAMP(x, [format]);

स्ट्रिंग x को एक टाइमस्टैम्प में कनवर्ट करता है।

8

TO_TIMESTAMP_TZ(x, [format]);

स्ट्रिंग x को टाइमस्टोन के साथ टाइमस्टैम्प में कनवर्ट करता है।

उदाहरण

निम्नलिखित कोड स्निपेट उपरोक्त कार्यों के उपयोग की व्याख्या करते हैं -

Example 1

SELECT SYSDATE FROM DUAL;

Output -

08/31/2012 5:25:34 PM

Example 2

SELECT TO_CHAR(CURRENT_DATE, 'DD-MM-YYYY HH:MI:SS') FROM DUAL;

Output -

31-08-2012 05:26:14

Example 3

SELECT ADD_MONTHS(SYSDATE, 5) FROM DUAL;

Output -

01/31/2013 5:26:31 PM

Example 4

SELECT LOCALTIMESTAMP FROM DUAL;

Output -

8/31/2012 5:26:55.347000 PM

अंतराल डेटा प्रकार और कार्य

निम्नलिखित अंतराल डेटा प्रकार हैं -

  • IINTERVAL YEAR TO MONTH - यह YEAR और MONTH डेटाइम फ़ील्ड का उपयोग करके समय की अवधि संग्रहीत करता है।

  • दूसरे दिन से दिन - यह दिन, घंटे, मिनट और सेकंड के मामले में समय की अवधि को संग्रहीत करता है।

अंतराल के कार्य

S.No समारोह का नाम और विवरण
1

NUMTODSINTERVAL(x, interval_unit);

संख्या X को अंतरिम दिन प्रति सेकंड में कनवर्ट करता है।

2

NUMTOYMINTERVAL(x, interval_unit);

एक आंतरिक वर्ष के लिए संख्या x को परिवर्तित करता है।

3

TO_DSINTERVAL(x);

स्ट्रिंग एक्स को एक दूसरे दिन के सेकंड के लिए परिवर्तित करता है।

4

TO_YMINTERVAL(x);

स्ट्रिंग एक्स को एक आंतरिक वर्ष के महीने में परिवर्तित करता है।