एसक्यूएल - तिथि कार्य

निम्न तालिका में SQL के माध्यम से उपलब्ध सभी महत्वपूर्ण दिनांक और समय से संबंधित कार्यों की एक सूची है। आपके RDBMS द्वारा समर्थित कई अन्य कार्य हैं। दी गई सूची MySQL RDBMS पर आधारित है।

अनु क्रमांक। समारोह विवरण
1 ADDDATE ()

तारीखें जोड़ता है

2 समय जोड़ें()

समय जोड़ता है

3 CONVERT_TZ ()

एक समयक्षेत्र से दूसरे में परिवर्तित होता है

4 CURDATE ()

वर्तमान दिनांक लौटाता है

5 CURRENT_DATE (), CURRENT_DATE

CURDATE के लिए समानार्थी ()

6 CURRENT_TIME (), CURRENT_TIME

CURTIME के ​​लिए समानार्थी ()

7 CURRENT_TIMESTAMP (), CURRENT_TIMESTAMP

अब के लिए समानार्थी ()

8 CURTIME ()

वर्तमान समय लौटाता है

9 DATE_ADD ()

दो तारीखें जोड़ता है

10 डेटा प्रारूप()

निर्दिष्ट के रूप में दिनांक

1 1 DATE_SUB ()

दो तिथियों को घटाता है

12 दिनांक()

किसी दिनांक या डेटाइम अभिव्यक्ति का दिनांक भाग निकालता है

13 DateDiff ()

दो तिथियों को घटाता है

14 (दिवस)

DAYOFMONTH का पर्यायवाची ()

15 DAYNAME ()

सप्ताह के दिन का नाम देता है

16 महीने का दिन()

महीने का दिन लौटाता है (1-31)

17 सप्ताह के दिन()

कार्यदिवस के तर्कों को लौटाता है

18 DAYOFYEAR ()

वर्ष का दिन लौटाता है (1-366)

19 उद्धरण

एक तारीख का हिस्सा निकालता है

20 FROM_DAYS ()

एक दिन की संख्या को एक तिथि में परिवर्तित करता है

21 FROM_UNIXTIME ()

प्रारूप एक UNIX टाइमस्टैम्प के रूप में है

22 इस घंटे ()

घंटा निकालता है

23 आखरी दिन

तर्क के लिए महीने का अंतिम दिन लौटाता है

24 LOCALTIME (), LOCALTIME

अब के लिए पर्यायवाची ()

25 LOCALTIMESTAMP, LOCALTIMESTAMP ()

अब के लिए पर्यायवाची ()

26 MAKEDATE ()

वर्ष और वर्ष के दिन से एक तारीख बनाता है

27 समय बनाना

समय बनाना()

28 माइक्रोसेकंड ()

माइक्रोसेकंड तर्क से देता है

29 मिनट ()

तर्क से मिनट लौटाता है

30 महीना()

बीती हुई तारीख से महीना लौटाओ

31 MONTHNAME ()

महीने का नाम लौटाता है

32 अभी()

वर्तमान दिनांक और समय लौटाता है

33 PERIOD_ADD ()

एक वर्ष-माह की अवधि जोड़ता है

34 PERIOD_DIFF ()

पीरियड्स के बीच महीनों की संख्या लौटाती है

35 त्रिमास()

दिनांक तर्क से तिमाही लौटाता है

36 SEC_TO_TIME ()

सेकंड को 'HH: MM: SS' प्रारूप में कनवर्ट करता है

37 दूसरा()

दूसरा रिटर्न (0-59)

38 STR_TO_DATE ()

एक स्ट्रिंग को एक तिथि में परिवर्तित करता है

39 SUBDATE ()

जब तीन तर्कों के साथ DATE_SUB () के लिए एक पर्याय

40 SUBTIME ()

घटाव बार

41 SYSDATE ()

उस समय को लौटाता है जिस पर फ़ंक्शन निष्पादित होता है

42 समय प्रारूप()

समय के रूप में प्रारूप

43 TIME_TO_SEC ()

सेकंड में परिवर्तित तर्क लौटाता है

44 समय()

उत्तीर्ण अभिव्यक्ति का समय भाग निकालता है

45 TIMEDIFF ()

समय घटाता है

46 TIMESTAMP ()

एक ही तर्क के साथ यह फ़ंक्शन दिनांक या डेटाइम एक्सप्रेशन देता है। दो तर्कों के साथ, तर्कों का योग

47 TIMESTAMPADD ()

एक डेटाटाइम अभिव्यक्ति के लिए एक अंतराल जोड़ता है

48 TIMESTAMPDIFF ()

डेटाइम एक्सप्रेशन से अंतराल को घटाता है

49 आज का दि()

दिनों में परिवर्तित दिनांक तर्क लौटाता है

50 UNIX_TIMESTAMP ()

एक UNIX टाइमस्टैम्प लौटाता है

51 UTC_DATE ()

वर्तमान UTC दिनांक लौटाता है

52 UTC_TIME ()

वर्तमान UTC समय लौटाता है

53 UTC_TIMESTAMP ()

वर्तमान UTC दिनांक और समय लौटाता है

54 सप्ताह()

सप्ताह का नंबर लौटाता है

55 WEEKDAY ()

कार्यदिवस सूचकांक लौटाता है

56 WEEKOFYEAR ()

दिनांक का कैलेंडर सप्ताह लौटाता है (1-53)

57 साल()

साल लौटता है

58 वर्ष सप्ताह ()

वर्ष और सप्ताह लौटाता है

ADDDATE (तिथि, अंतरिम expr इकाई), ADDDATE (expr, days)

जब दूसरे तर्क के INTERVAL रूप से आमंत्रित किया जाता है, तो ADDDATE () DATE_ADD () के लिए एक पर्याय बन जाता है। संबंधित फ़ंक्शन SUBDATE () DATE_SUB () के लिए एक पर्याय है। INTERVAL इकाई तर्क पर जानकारी के लिए, DATE_ADD () के लिए चर्चा देखें।

mysql> SELECT DATE_ADD('1998-01-02', INTERVAL 31 DAY);
+---------------------------------------------------------+
| DATE_ADD('1998-01-02', INTERVAL 31 DAY)                 |
+---------------------------------------------------------+
| 1998-02-02                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT ADDDATE('1998-01-02', INTERVAL 31 DAY);
+---------------------------------------------------------+
| ADDDATE('1998-01-02', INTERVAL 31 DAY)                  |
+---------------------------------------------------------+
| 1998-02-02                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

जब दूसरे तर्क के दिनों के फॉर्म के साथ इनवाइट किया जाता है, तो MySQL एक्सपायर होने के लिए इसे कुछ दिनों के पूर्णांक संख्या के रूप में मानता है।

mysql> SELECT ADDDATE('1998-01-02', 31);
+---------------------------------------------------------+
| DATE_ADD('1998-01-02', INTERVAL 31 DAY)                 |
+---------------------------------------------------------+
| 1998-02-02                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

ADDTIME (expr1, expr2)

ADDTIME () expr1 को expr1 में जोड़ता है और परिणाम देता है। Expr1 एक समय या डेटाटाइम अभिव्यक्ति है, जबकि expr2 एक समय अभिव्यक्ति है।

mysql> SELECT ADDTIME('1997-12-31 23:59:59.999999','1 1:1:1.000002');
+---------------------------------------------------------+
| DATE_ADD('1997-12-31 23:59:59.999999','1 1:1:1.000002') |
+---------------------------------------------------------+
| 1998-01-02 01:01:01.000001                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

CONVERT_TZ (डीटी, from_tz, to_tz)

यह to_tz द्वारा दिए गए समय क्षेत्र to_tz द्वारा दिए गए समय क्षेत्र से एक डेटाइम मान dt को कनवर्ट करता है और परिणामी मान लौटाता है। यदि तर्क अमान्य हैं, तो यह फ़ंक्शन NULL देता है।

mysql> SELECT CONVERT_TZ('2004-01-01 12:00:00','GMT','MET');
+---------------------------------------------------------+
| CONVERT_TZ('2004-01-01 12:00:00','GMT','MET')           |
+---------------------------------------------------------+
| 2004-01-01 13:00:00                                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT CONVERT_TZ('2004-01-01 12:00:00','+00:00','+10:00');
+---------------------------------------------------------+
| CONVERT_TZ('2004-01-01 12:00:00','+00:00','+10:00')     |
+---------------------------------------------------------+
| 2004-01-01 22:00:00                                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

CURDATE ()

वर्तमान दिनांक को 'YYYY-MM-DD' या YYYYMMDD प्रारूप में मान के रूप में लौटाता है, यह इस बात पर निर्भर करता है कि फ़ंक्शन स्ट्रिंग में या संख्यात्मक संदर्भ में उपयोग किया जाता है।

mysql> SELECT CURDATE();
+---------------------------------------------------------+
| CURDATE()                                               |
+---------------------------------------------------------+
| 1997-12-15                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT CURDATE() + 0;
+---------------------------------------------------------+
| CURDATE() + 0                                           |
+---------------------------------------------------------+
| 19971215                                                |
+---------------------------------------------------------+
1 row in set (0.00 sec)

CURRENT_DATE और CURRENT_DATE ()

CURRENT_DATE और CURRENT_DATE () CURDATE () के पर्यायवाची हैं

CURTIME ()

वर्तमान समय को 'HH: MM: SS' या HHMMSS प्रारूप में मान के रूप में लौटाता है, यह इस बात पर निर्भर करता है कि फ़ंक्शन स्ट्रिंग में या संख्यात्मक संदर्भ में उपयोग किया जाता है। मान वर्तमान समय क्षेत्र में व्यक्त किया गया है।

mysql> SELECT CURTIME();
+---------------------------------------------------------+
| CURTIME()                                               |
+---------------------------------------------------------+
| 23:50:26                                                |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT CURTIME() + 0;
+---------------------------------------------------------+
| CURTIME() + 0                                           |
+---------------------------------------------------------+
| 235026                                                  |
+---------------------------------------------------------+
1 row in set (0.00 sec)

CURRENT_TIME और CURRENT_TIME ()

CURRENT_TIME और CURRENT_TIME () CURTIME के ​​पर्यायवाची हैं ()।

CURRENT_TIMESTAMP और CURRENT_TIMESTAMP ()

CURRENT_TIMESTAMP और CURRENT_TIMESTAMP () अब के लिए पर्यायवाची हैं ()।

DATE (expr)

तिथि या डेटाइम एक्सप्रेशन का दिनांक भाग निकालता है।

mysql> SELECT DATE('2003-12-31 01:02:03');
+---------------------------------------------------------+
| DATE('2003-12-31 01:02:03')                             |
+---------------------------------------------------------+
|  2003-12-31                                             |
+---------------------------------------------------------+
1 row in set (0.00 sec)

DateDiff (expr1, expr2)

DatedIFF () रिटर्न expr1। expr2 एक तारीख से दूसरी तारीख के दिनों में एक मूल्य के रूप में व्यक्त किया। Expr1 और expr2 दोनों ही तारीख या तारीख और समय के भाव हैं। गणना में केवल मूल्यों के दिनांक भागों का उपयोग किया जाता है।

mysql> SELECT DATEDIFF('1997-12-31 23:59:59','1997-12-30');
+---------------------------------------------------------+
| DATEDIFF('1997-12-31 23:59:59','1997-12-30')            |
+---------------------------------------------------------+
| 1                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

DATE_ADD (दिनांक, INTERVAL expr यूनिट), DATE_SUB (तिथि, अंतरिम expr इकाई)

ये कार्य तिथि अंकगणित करते हैं। dateप्रारंभ दिनांक निर्दिष्ट करने का एक DATETIME या DATE मान है। exprएक अभिव्यक्ति है जो अंतराल मूल्य को निर्दिष्ट तिथि से जोड़ा या घटाया जाता है। एक्सपायर एक स्ट्रिंग है; यह नकारात्मक अंतराल के लिए '-' से शुरू हो सकता है।

unit एक ऐसा कीवर्ड है जो इकाइयों को दर्शाता है जिसमें अभिव्यक्ति की व्याख्या की जानी चाहिए।

INTERVAL कीवर्ड और यूनिट स्पेसिफिक केस सेंसिटिव नहीं हैं।

निम्न तालिका प्रत्येक इकाई मान के लिए expr तर्क का अपेक्षित रूप दिखाती है।

ईकाइ का मूल्य प्रत्याशित विस्तार
माइक्रोसेकंड माइक्रोसेकंड
दूसरा सेकंड
मिनट मिनट
इस घंटे घंटे
दिन दिन
सप्ताह हफ्तों
महीना महीने
त्रिमास तिमाहियों
साल वर्षों
SECOND_MICROSECOND 'SECONDS.MICROSECONDS'
MINUTE_MICROSECOND 'MINUTES.MICROSECONDS'
MINUTE_SECOND 'MINUTES: SECONDS'
HOUR_MICROSECOND 'HOURS.MICROSECONDS'
HOUR_SECOND 'घंटे: मिनट: सेकंड'
HOUR_MINUTE 'HOURS: MINUTES'
DAY_MICROSECOND 'DAYS.MICROSECONDS'
DAY_SECOND 'दिन भर: मिनट: सेकंड'
DAY_MINUTE 'दिन भर: मिनट'
DAY_HOUR 'डेस हॉर्स'
वर्ष माह 'साल महीने का

मूल्य QUARTER तथा WEEKMySQL 5.0.0 से उपलब्ध हैं। संस्करण।

mysql> SELECT DATE_ADD('1997-12-31 23:59:59', 
   -> INTERVAL '1:1' MINUTE_SECOND);
+---------------------------------------------------------+
| DATE_ADD('1997-12-31 23:59:59', INTERVAL...             |
+---------------------------------------------------------+
| 1998-01-01 00:01:00                                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT DATE_ADD('1999-01-01', INTERVAL 1 HOUR);
+---------------------------------------------------------+
| DATE_ADD('1999-01-01', INTERVAL 1 HOUR)                 |
+---------------------------------------------------------+
| 1999-01-01 01:00:00                                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

DATE_FORMAT (तिथि, स्वरूप)

यह कमांड प्रारूप स्ट्रिंग के अनुसार दिनांक मान को प्रारूपित करता है।

प्रारूप स्ट्रिंग में निम्नलिखित विनिर्देशक का उपयोग किया जा सकता है। प्रारूप निर्दिष्ट वर्णों से पहले '%' वर्ण आवश्यक है।

अनु क्रमांक। विनिर्देशक और विवरण
1

%a

संक्षिप्त सप्ताह का नाम (Sun..Sat)

2

%b

संक्षिप्त माह का नाम (Jan..Dec)

3

%c

महीना, संख्यात्मक (0..12)

4

%D

अंग्रेजी प्रत्यय के साथ महीने का दिन (0th, 1st, 2nd, 3rd,)

5

%d

महीने का दिन, संख्यात्मक (00..31)

6

%e

महीने का दिन, संख्यात्मक (0..31)

7

%f

माइक्रोसेकंड (000000..999999)

8

%H

घंटा (00..23)

9

%h

घंटा (01..12)

10

%I

घंटा (01..12)

1 1

%i

मिनट, संख्यात्मक (00..59)

12

%j

वर्ष का दिन (001..366)

13

%k

घंटा (0..23)

14

%l

घंटा (1..12)

15

%M

माह का नाम (जनवरी..दिन)

16

%m

महीना, संख्यात्मक (00..12)

17

%p

पूर्वाह्न या अपराह्न

18

%r

समय, 12-घंटे (hh: mm: ss इसके बाद AM या PM)

19

%S

सेकंड (00..59)

20

%s

सेकंड (00..59)

21

%T

समय, 24-घंटे (hh: mm: ss)

22

%U

सप्ताह (00..53), जहां रविवार सप्ताह का पहला दिन है

23

%u

सप्ताह (00..53), जहां सोमवार सप्ताह का पहला दिन है

24

%V

सप्ताह (01..53), जहां रविवार सप्ताह का पहला दिन है; % X के साथ उपयोग किया जाता है

25

%v

सप्ताह (01..53), जहां सोमवार सप्ताह का पहला दिन है; % x के साथ उपयोग किया जाता है

26

%W

सप्ताह का नाम (रविवार)

27

%w

सप्ताह का दिन (0 = रविवार।.6 = शनिवार)

28

%X

सप्ताह के लिए वर्ष जहां रविवार सप्ताह का पहला दिन है, संख्यात्मक, चार अंक; % V के साथ उपयोग किया जाता है

29

%x

सप्ताह के लिए वर्ष, जहां सोमवार सप्ताह का पहला दिन है, संख्यात्मक, चार अंक; % v के साथ उपयोग किया जाता है

30

%Y

वर्ष, अंक, चार अंक

31

%y

वर्ष, संख्यात्मक (दो अंक)

32

%%

एक शाब्दिक।%। चरित्र

33

%x

x, किसी भी के लिए। x ऊपर सूचीबद्ध नहीं है

mysql> SELECT DATE_FORMAT('1997-10-04 22:23:00', '%W %M %Y');
+---------------------------------------------------------+
| DATE_FORMAT('1997-10-04 22:23:00', '%W %M %Y')          |
+---------------------------------------------------------+
| Saturday October 1997                                   |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT DATE_FORMAT('1997-10-04 22:23:00'
   -> '%H %k %I %r %T %S %w');
+---------------------------------------------------------+
| DATE_FORMAT('1997-10-04 22:23:00.......                 |
+---------------------------------------------------------+
|  22 22 10 10:23:00 PM 22:23:00 00 6                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

DATE_SUB (तिथि, अंतरिम विस्तार इकाई)

यह DATE_ADD () फ़ंक्शन के समान है।

दिन दिनांक)

DAY () DAYOFMONTH () फ़ंक्शन का एक पर्याय है।

DAYNAME (तारीख)

दिनांक के लिए कार्यदिवस का नाम देता है।

mysql> SELECT DAYNAME('1998-02-05');
+---------------------------------------------------------+
| DAYNAME('1998-02-05')                                   |
+---------------------------------------------------------+
| Thursday                                                |
+---------------------------------------------------------+
1 row in set (0.00 sec)

DAYOFMONTH (तारीख)

तारीख के लिए महीने का दिन लौटाता है, 0 से 31 की सीमा में।

mysql> SELECT DAYOFMONTH('1998-02-03');
+---------------------------------------------------------+
| DAYOFMONTH('1998-02-03')                                |
+---------------------------------------------------------+
| 3                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

DAYOFWEEK (तारीख)

दिनांक (1 = रविवार, 2 = सोमवार,।, 7 = शनिवार) के लिए कार्यदिवस सूचकांक लौटाता है। ये सूचकांक मान ODBC मानक के अनुरूप हैं।

mysql> SELECT DAYOFWEEK('1998-02-03');
+---------------------------------------------------------+
|DAYOFWEEK('1998-02-03')                                  |
+---------------------------------------------------------+
| 3                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

DAYOFYEAR (तारीख)

1 से 366 के बीच की तारीख के लिए वर्ष का दिन लौटाता है।

mysql> SELECT DAYOFYEAR('1998-02-03');
+---------------------------------------------------------+
| DAYOFYEAR('1998-02-03')                                 |
+---------------------------------------------------------+
| 34                                                      |
+---------------------------------------------------------+
1 row in set (0.00 sec)

एक्सट्रैक्ट (यूनिट से तारीख)

EXTRACT () फ़ंक्शन DATE_ADD () या DATE_SUB () के रूप में एक ही प्रकार की इकाई निर्दिष्टकर्ताओं का उपयोग करता है, लेकिन तारीख अंकगणित करने के बजाय दिनांक से भागों को निकालता है।

mysql> SELECT EXTRACT(YEAR FROM '1999-07-02');
+---------------------------------------------------------+
| EXTRACT(YEAR FROM '1999-07-02')                         |
+---------------------------------------------------------+
| 1999                                                    |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT EXTRACT(YEAR_MONTH FROM '1999-07-02 01:02:03');
+---------------------------------------------------------+
| EXTRACT(YEAR_MONTH FROM '1999-07-02 01:02:03')          |
+---------------------------------------------------------+
| 199907                                                  |
+---------------------------------------------------------+
1 row in set (0.00 sec)

FROM_DAYS (एन)

एक दिन की संख्या N को देखते हुए, DATE मान लौटाता है।

mysql> SELECT FROM_DAYS(729669);
+---------------------------------------------------------+
| FROM_DAYS(729669)                                       |
+---------------------------------------------------------+
| 1997-10-07                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

Note- पुरानी तारीखों में सावधानी के साथ FROM_DAYS () का उपयोग करें। यह उन मूल्यों के साथ उपयोग करने के लिए अभिप्रेत नहीं है जो ग्रेगोरियन कैलेंडर (1582) के आगमन से पहले थे।

FROM_UNIXTIME (unix_timestamp)

FROM_UNIXTIME (unix_timestamp, प्रारूप)

का प्रतिनिधित्व करता है unix_timestamp'YYYY-MM-DD HH: MM: SS या YYYYMMDDHHMMSS प्रारूप में एक मान के रूप में तर्क, फ़ंक्शन एक स्ट्रिंग में या एक संख्यात्मक संदर्भ में उपयोग किया जाता है, इस पर निर्भर करता है। मान वर्तमान समय क्षेत्र में व्यक्त किया गया है। Unix_timestamp तर्क एक आंतरिक टाइमस्टैम्प मान है, जो द्वारा निर्मित होते हैंUNIX_TIMESTAMP() समारोह।

यदि प्रारूप दिया जाता है, तो परिणाम स्वरूप स्ट्रिंग के अनुसार स्वरूपित किया जाता है, जिसका उपयोग उसी तरीके से किया जाता है जैसा कि प्रविष्टि में सूचीबद्ध है DATE_FORMAT() समारोह।

mysql> SELECT FROM_UNIXTIME(875996580);
+---------------------------------------------------------+
| FROM_UNIXTIME(875996580)                                |
+---------------------------------------------------------+
| 1997-10-04 22:23:00                                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

इस घंटे (समय)

समय के लिए घंटे लौटाता है। समय मान के लिए वापसी मान की सीमा 0 से 23 है। हालाँकि, TIME मानों की श्रेणी वास्तव में बहुत बड़ी है, इसलिए HOUR मानों को 23 से अधिक वापस कर सकता है।

mysql> SELECT HOUR('10:05:03');
+---------------------------------------------------------+
| HOUR('10:05:03')                                        |
+---------------------------------------------------------+
| 10                                                      |
+---------------------------------------------------------+
1 row in set (0.00 sec)

LAST_DAY (तारीख)

दिनांक या डेटाटाइम मान लेता है और महीने के अंतिम दिन के लिए संबंधित मान लौटाता है। यदि तर्क अमान्य है, तो NULL लौटाता है।

mysql> SELECT LAST_DAY('2003-02-05');
+---------------------------------------------------------+
| LAST_DAY('2003-02-05')                                  |
+---------------------------------------------------------+
| 2003-02-28                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

LOCALTIME और LOCALTIME ()

LOCALTIME और LOCALTIME () अभी के लिए पर्यायवाची हैं ()।

LOCALTIMESTAMP और LOCALTIMESTAMP ()

LOCALTIMESTAMP और LOCALTIMESTAMP () अब के लिए पर्यायवाची हैं ()।

MAKEDATE (वर्ष, dayofyear)

वर्ष और दिन के मूल्यों को देखते हुए, एक तारीख लौटाता है। Dayofyear मान 0 से अधिक होना चाहिए या परिणाम NULL होगा।

mysql> SELECT MAKEDATE(2001,31), MAKEDATE(2001,32);
+---------------------------------------------------------+
| MAKEDATE(2001,31), MAKEDATE(2001,32)                    |
+---------------------------------------------------------+
| '2001-01-31', '2001-02-01'                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

MAKETIME (घंटा, मिनट, सेकंड)

समय, मिनट और दूसरे तर्कों से गणना की गई समय मान लौटाता है।

mysql> SELECT MAKETIME(12,15,30);
+---------------------------------------------------------+
| MAKETIME(12,15,30)                                      |
+---------------------------------------------------------+
| '12:15:30'                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

माइक्रोसेकंड (expr)

0 से 999999 तक के समय में एक संख्या के रूप में समय या डेटाइम एक्सप्रेशन (expr) से माइक्रोसेकंड लौटाता है।

mysql> SELECT MICROSECOND('12:00:00.123456');
+---------------------------------------------------------+
| MICROSECOND('12:00:00.123456')                          |
+---------------------------------------------------------+
| 123456                                                  |
+---------------------------------------------------------+
1 row in set (0.00 sec)

मिनट (समय)

0 से 59 की सीमा में, समय के लिए मिनट देता है।

mysql> SELECT MINUTE('98-02-03 10:05:03');
+---------------------------------------------------------+
| MINUTE('98-02-03 10:05:03')                             |
+---------------------------------------------------------+
| 5                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

महीना दिनांक)

0 से 12 की रेंज में, तारीख के लिए महीना लौटाता है।

mysql> SELECT MONTH('1998-02-03')
+---------------------------------------------------------+
| MONTH('1998-02-03')                                     |
+---------------------------------------------------------+
| 2                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

MONTHNAME (तारीख)

तारीख के लिए महीने का पूरा नाम देता है।

mysql> SELECT MONTHNAME('1998-02-05');
+---------------------------------------------------------+
| MONTHNAME('1998-02-05')                                 |
+---------------------------------------------------------+
| February                                                |
+---------------------------------------------------------+
1 row in set (0.00 sec)

अभी()

'YYYY-MM-DD-HH: MM: SS' या YYYYMMDDHHMMSS प्रारूप में मान के रूप में वर्तमान दिनांक और समय लौटाता है, यह इस बात पर निर्भर करता है कि फ़ंक्शन का उपयोग स्ट्रिंग या संख्यात्मक संदर्भ में किया गया है। यह मान वर्तमान समय क्षेत्र में व्यक्त किया गया है।

mysql> SELECT NOW();
+---------------------------------------------------------+
| NOW()                                                   |
+---------------------------------------------------------+
| 1997-12-15 23:50:26                                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

PERIOD_ADD (पी, एन)

P (N को YYMM या YYYMM प्रारूप में) एक अवधि के लिए N महीने जोड़ता है। YYYYMM प्रारूप में एक मान देता है। ध्यान दें कि पीरियड तर्क P कोई दिनांक मान नहीं है।

mysql> SELECT PERIOD_ADD(9801,2);
+---------------------------------------------------------+
| PERIOD_ADD(9801,2)                                      |
+---------------------------------------------------------+
| 199803                                                  |
+---------------------------------------------------------+
1 row in set (0.00 sec)

PERIOD_DIFF (P1, P2)

पी 1 और पी 2 के बीच महीनों की संख्या लौटाता है। ये अवधि P1 और P2 प्रारूप YYMM या YYYMM में होनी चाहिए। ध्यान दें कि पी 1 और पी 2 की अवधि तर्क तारीख मान नहीं है।

mysql> SELECT PERIOD_DIFF(9802,199703);
+---------------------------------------------------------+
| PERIOD_DIFF(9802,199703)                                |
+---------------------------------------------------------+
| 11                                                      |
+---------------------------------------------------------+
1 row in set (0.00 sec)

तिमाही (तारीख)

1 से 4 के बीच की तारीख के लिए वर्ष की तिमाही लौटाता है।

mysql> SELECT QUARTER('98-04-01');
+---------------------------------------------------------+
| QUARTER('98-04-01')                                     |
+---------------------------------------------------------+
| 2                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

दूसरी बार)

0 से 59 के बीच, समय के लिए दूसरा लौटाता है।

mysql> SELECT SECOND('10:05:03');
+---------------------------------------------------------+
| SECOND('10:05:03')                                      |
+---------------------------------------------------------+
| 3                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

SEC_TO_TIME (सेकंड)

'HH: MM: SS' या HHMMSS प्रारूप में मान के रूप में घंटे, मिनट और सेकंड में परिवर्तित सेकंड तर्क लौटाता है, यह इस बात पर निर्भर करता है कि फ़ंक्शन एक स्ट्रिंग या संख्यात्मक संदर्भ में उपयोग किया जाता है।

mysql> SELECT SEC_TO_TIME(2378);
+---------------------------------------------------------+
| SEC_TO_TIME(2378)                                       |
+---------------------------------------------------------+
| 00:39:38                                                |
+---------------------------------------------------------+
1 row in set (0.00 sec)

STR_TO_DATE (str, प्रारूप)

यह DATE_FORMAT () फ़ंक्शन का व्युत्क्रम है। यह एक स्ट्रिंग स्ट्रिंग और एक प्रारूप स्ट्रिंग प्रारूप लेता है। STR_TO_DATE () फ़ंक्शन DATETIME मान लौटाता है यदि प्रारूप स्ट्रिंग में दिनांक और समय दोनों भाग होते हैं। यदि स्ट्रिंग में केवल दिनांक या समय भाग होते हैं, तो यह एक DATE या TIME मान देता है।

mysql> SELECT STR_TO_DATE('04/31/2004', '%m/%d/%Y');
+---------------------------------------------------------+
| STR_TO_DATE('04/31/2004', '%m/%d/%Y')                   |
+---------------------------------------------------------+
| 2004-04-31                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

SUBDATE (तारीख, INTERVAL expr यूनिट) और SUBDATE (expr, days)

जब दूसरे तर्क के INTERVAL रूप से आमंत्रित किया जाता है, तो SUBDATE () DATE_SUB () के लिए एक पर्याय है। INTERVAL इकाई तर्क पर जानकारी के लिए, DATE_ADD () के लिए चर्चा देखें।

mysql> SELECT DATE_SUB('1998-01-02', INTERVAL 31 DAY);
+---------------------------------------------------------+
| DATE_SUB('1998-01-02', INTERVAL 31 DAY)                 |
+---------------------------------------------------------+
| 1997-12-02                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT SUBDATE('1998-01-02', INTERVAL 31 DAY);
+---------------------------------------------------------+
| SUBDATE('1998-01-02', INTERVAL 31 DAY)                  |
+---------------------------------------------------------+
| 1997-12-02                                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

SUBTIME (expr1, expr2)

सबटाइम () फ़ंक्शन रिटर्न expr1 है। expr2 expr1 के समान प्रारूप में एक मूल्य के रूप में व्यक्त किया गया है। Expr1 मान एक समय या डेटाइम अभिव्यक्ति है, जबकि expr2 मान एक समय अभिव्यक्ति है।

mysql> SELECT SUBTIME('1997-12-31 23:59:59.999999',
   -> '1 1:1:1.000002');
+---------------------------------------------------------+
| SUBTIME('1997-12-31 23:59:59.999999'...                 |
+---------------------------------------------------------+
| 1997-12-30 22:58:58.999997                              |
+---------------------------------------------------------+
1 row in set (0.00 sec)

SYSDATE ()

वर्तमान दिनांक और समय को 'YYYY-MM-DD-HH: MM: SS' या YYYYMMDDHHMMSS प्रारूप में मान के रूप में लौटाता है, यह इस बात पर निर्भर करता है कि फ़ंक्शन स्ट्रिंग में या संख्यात्मक संदर्भ में उपयोग किया जाता है।

mysql> SELECT SYSDATE();
+---------------------------------------------------------+
| SYSDATE()                                               |
+---------------------------------------------------------+
| 2006-04-12 13:47:44                                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

समय (expr)

समय या डेटाटाइम अभिव्यक्ति का समय भाग निकालता है expr और इसे एक स्ट्रिंग के रूप में लौटाता है।

mysql> SELECT TIME('2003-12-31 01:02:03');
+---------------------------------------------------------+
| TIME('2003-12-31 01:02:03')                             |
+---------------------------------------------------------+
| 01:02:03                                                |
+---------------------------------------------------------+
1 row in set (0.00 sec)

TIMEDIFF (expr1, expr2)

TIMEDIFF () फ़ंक्शन रिटर्न expr1 है। expr2 एक समय मूल्य के रूप में व्यक्त किया। ये expr1 और expr2 मान समय या दिनांक और समय के भाव हैं, लेकिन दोनों एक ही प्रकार के होने चाहिए।

mysql> SELECT TIMEDIFF('1997-12-31 23:59:59.000001',
   -> '1997-12-30 01:01:01.000002');
+---------------------------------------------------------+
| TIMEDIFF('1997-12-31 23:59:59.000001'.....              |
+---------------------------------------------------------+
|  46:58:57.999999                                        |
+---------------------------------------------------------+
1 row in set (0.00 sec)

TIMESTAMP (expr), TIMESTAMP (expr1, expr2)

एकल तर्क के साथ, यह फ़ंक्शन डेट या डेटटाइम एक्सप्रेशन को डेटाइम मान के रूप में वापस करता है। दो तर्कों के साथ, यह समय अभिव्यक्ति expr2 को तिथि या डेटाइम अभिव्यक्ति में जोड़ता हैexpr1 और परिणाम को डेटाइम मान के रूप में लौटाता है।

mysql> SELECT TIMESTAMP('2003-12-31');
+---------------------------------------------------------+
| TIMESTAMP('2003-12-31')                                 |
+---------------------------------------------------------+
| 2003-12-31 00:00:00                                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

TIMESTAMPADD (इकाई, अंतराल, datetime_expr)

यह फ़ंक्शन दिनांक या डेटाटाइम अभिव्यक्ति के लिए पूर्णांक अभिव्यक्ति अंतराल जोड़ता है datetime_expr। अंतराल के लिए इकाई इकाई तर्क द्वारा दी गई है, जो निम्नलिखित मानों में से एक होना चाहिए -

  • FRAC_SECOND
  • सेकंड, मिनट
  • हूर, दिन
  • WEEK
  • MONTH
  • खदान या
  • YEAR

दिखाए गए या SQL_TSI_ के उपसर्ग के साथ किसी एक कीवर्ड का उपयोग करके यूनिट मान निर्दिष्ट किया जा सकता है।

उदाहरण के लिए, DAY और SQL_TSI_DAY दोनों कानूनी हैं।

mysql> SELECT TIMESTAMPADD(MINUTE,1,'2003-01-02');
+---------------------------------------------------------+
| TIMESTAMPADD(MINUTE,1,'2003-01-02')                     |
+---------------------------------------------------------+
| 2003-01-02 00:01:00                                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

TIMESTAMPDIFF (इकाई, datetime_expr1, datetime_expr2)

दिनांक या डेटाटाइम अभिव्यक्तियों datetime_expr1 और datetime_expr2 के बीच पूर्णांक अंतर देता है। परिणाम के लिए इकाई इकाई तर्क द्वारा दी गई है। यूनिट के लिए कानूनी मूल्य वही हैं जो TIMESTAMPADD () फ़ंक्शन के विवरण में सूचीबद्ध हैं।

mysql> SELECT TIMESTAMPDIFF(MONTH,'2003-02-01','2003-05-01');
+---------------------------------------------------------+
| TIMESTAMPDIFF(MONTH,'2003-02-01','2003-05-01')          |
+---------------------------------------------------------+
| 3                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

TIME_FORMAT (समय, प्रारूप)

यह फ़ंक्शन DATE_FORMAT () फ़ंक्शन की तरह उपयोग किया जाता है, लेकिन प्रारूप स्ट्रिंग में केवल घंटे, मिनट और सेकंड के लिए प्रारूप विनिर्देशक हो सकते हैं।

यदि समय मान में एक घंटे का हिस्सा है जो 23 से अधिक है, तो%H तथा %k घंटे प्रारूप विनिर्देशक 0 से 23 की सामान्य श्रेणी की तुलना में बड़ा मान उत्पन्न करते हैं। अन्य घंटे प्रारूप विनिर्देशक घंटे मान मोडुलो 12 का उत्पादन करते हैं।

mysql> SELECT TIME_FORMAT('100:00:00', '%H %k %h %I %l');
+---------------------------------------------------------+
| TIME_FORMAT('100:00:00', '%H %k %h %I %l')              |
+---------------------------------------------------------+
| 100 100 04 04 4                                         |
+---------------------------------------------------------+
1 row in set (0.00 sec)

TIME_TO_SEC (समय)

सेकंड में परिवर्तित समय तर्क लौटाता है।

mysql> SELECT TIME_TO_SEC('22:23:00');
+---------------------------------------------------------+
| TIME_TO_SEC('22:23:00')                                 |
+---------------------------------------------------------+
| 80580                                                   |
+---------------------------------------------------------+
1 row in set (0.00 sec)

आज की तारीख)

एक तारीख को देखते हुए, एक दिन की संख्या (वर्ष 0 के बाद के दिनों की संख्या) लौटाता है।

mysql> SELECT TO_DAYS(950501);
+---------------------------------------------------------+
| TO_DAYS(950501)                                         |
+---------------------------------------------------------+
| 728779                                                  |
+---------------------------------------------------------+
1 row in set (0.00 sec)

UNIX_TIMESTAMP (), UNIX_TIMESTAMP (दिनांक)

यदि कोई तर्क नहीं कहा जाता है, तो यह फ़ंक्शन एक अहस्ताक्षरित पूर्णांक के रूप में एक यूनिक्स टाइमस्टैम्प ('1970-01-01 00:00:00' यूटीसी के बाद से) देता है। यदि UNIX_TIMESTAMP () को डेट तर्क के साथ कहा जाता है, तो यह '1970-01-01 00:00:00' UTC के बाद से सेकंड के रूप में तर्क का मान लौटाता है। दिनांक DATE स्ट्रिंग, DATETIME स्ट्रिंग, TIMESTAMP, या स्वरूप YYMMDD या YYYYMMDD में एक संख्या हो सकती है।

mysql> SELECT UNIX_TIMESTAMP();
+---------------------------------------------------------+
| UNIX_TIMESTAMP()                                        |
+---------------------------------------------------------+
| 882226357                                               |
+---------------------------------------------------------+
1 row in set (0.00 sec)

mysql> SELECT UNIX_TIMESTAMP('1997-10-04 22:23:00');
+---------------------------------------------------------+
| UNIX_TIMESTAMP('1997-10-04 22:23:00')                   |
+---------------------------------------------------------+
| 875996580                                               |
+---------------------------------------------------------+
1 row in set (0.00 sec)

UTC_DATE, UTC_DATE ()

वर्तमान UTC दिनांक को 'YYYY-MM-DD' या YYYYMMDD प्रारूप में मान के रूप में लौटाता है, जो इस बात पर निर्भर करता है कि फ़ंक्शन का उपयोग स्ट्रिंग या संख्यात्मक संदर्भ में किया गया है।

mysql> SELECT UTC_DATE(), UTC_DATE() + 0;
+---------------------------------------------------------+
| UTC_DATE(), UTC_DATE() + 0                              |
+---------------------------------------------------------+
| 2003-08-14, 20030814                                    |
+---------------------------------------------------------+
1 row in set (0.00 sec)

UTC_TIME, UTC_TIME ()

'UH: MM: SS' या HHMMSS प्रारूप में मान के रूप में वर्तमान UTC समय लौटाता है, यह इस बात पर निर्भर करता है कि फ़ंक्शन का उपयोग स्ट्रिंग या संख्यात्मक संदर्भ में किया गया है।

mysql> SELECT UTC_TIME(), UTC_TIME() + 0;
+---------------------------------------------------------+
| UTC_TIME(), UTC_TIME() + 0                              |
+---------------------------------------------------------+
| 18:07:53, 180753                                        |
+---------------------------------------------------------+
1 row in set (0.00 sec)

UTC_TIMESTAMP, UTC_TIMESTAMP ()

वर्तमान UTC दिनांक और समय को 'YYYY-MM-DD HH: MM: SS' या YYYMMDDHHMMSS प्रारूप में मान के रूप में लौटाता है, यह इस बात पर निर्भर करता है कि फ़ंक्शन स्ट्रिंग में या संख्यात्मक संदर्भ में उपयोग किया जाता है।

mysql> SELECT UTC_TIMESTAMP(), UTC_TIMESTAMP() + 0;
+---------------------------------------------------------+
| UTC_TIMESTAMP(), UTC_TIMESTAMP() + 0                    |
+---------------------------------------------------------+
| 2003-08-14 18:08:04, 20030814180804                     |
+---------------------------------------------------------+
1 row in set (0.00 sec)

सप्ताह (तारीख [, मोड])

यह फ़ंक्शन दिनांक के लिए सप्ताह नंबर देता है। WEEK का दो-तर्क रूप () आपको यह निर्दिष्ट करने की अनुमति देता है कि सप्ताह रविवार या सोमवार को शुरू होता है या नहीं और वापसी मान 0 से 53 तक या 1 से 53 तक होना चाहिए। यदि मोड तर्क छोड़ा गया है, Default_week_format सिस्टम वैरिएबल के मान का उपयोग किया जाता है

मोड सप्ताह का पहला दिन रेंज सप्ताह 1 पहला सप्ताह है।
0 रविवार 0-53 इस वर्ष में एक रविवार के साथ
1 सोमवार 0-53 इस वर्ष 3 से अधिक दिनों के साथ
2 रविवार 1-53 इस वर्ष में एक रविवार के साथ
3 सोमवार 1-53 इस वर्ष 3 से अधिक दिनों के साथ
4 रविवार 0-53 इस वर्ष 3 से अधिक दिनों के साथ
5 सोमवार 0-53 इस वर्ष में एक सोमवार के साथ
6 रविवार 1-53 इस वर्ष 3 से अधिक दिनों के साथ
7 सोमवार 1-53 इस वर्ष में एक सोमवार के साथ
mysql> SELECT WEEK('1998-02-20');
+---------------------------------------------------------+
| WEEK('1998-02-20')                                      |
+---------------------------------------------------------+
| 7                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

WEEKDAY (तारीख)

दिनांक (0 = सोमवार, 1 = मंगलवार, 6 = रविवार) के लिए कार्यदिवस सूचकांक लौटाता है।

mysql> SELECT WEEKDAY('1998-02-03 22:23:00');
+---------------------------------------------------------+
| WEEKDAY('1998-02-03 22:23:00')                          |
+---------------------------------------------------------+
| 1                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

WEEKOFYEAR (तारीख)

दिनांक का कैलेंडर सप्ताह 1 से 53 तक की संख्या के रूप में देता है। WEEKOFYEAR () एक संगतता फ़ंक्शन है जो WEEK (दिनांक, 3) के बराबर है।

mysql> SELECT WEEKOFYEAR('1998-02-20');
+---------------------------------------------------------+
| WEEKOFYEAR('1998-02-20')                                |
+---------------------------------------------------------+
| 8                                                       |
+---------------------------------------------------------+
1 row in set (0.00 sec)

वर्ष (तारीख)

वर्ष के लिए रिटर्न, 1000 से 9999 की रेंज में, या .zero के लिए 0। दिनांक।

mysql> SELECT YEAR('98-02-03');
+---------------------------------------------------------+
| YEAR('98-02-03')                                        |
+---------------------------------------------------------+
| 1998                                                    |
+---------------------------------------------------------+
1 row in set (0.00 sec)

YEARWEEK (तारीख), YEARWEEK (तारीख, मोड)

तारीख के लिए वर्ष और सप्ताह लौटाता है। मोड तर्क बिल्कुल WEEK () फ़ंक्शन के लिए मोड तर्क की तरह काम करता है। परिणाम में वर्ष वर्ष के पहले और अंतिम सप्ताह के लिए तारीख तर्क में वर्ष से भिन्न हो सकता है।

mysql> SELECT YEARWEEK('1987-01-01');
+---------------------------------------------------------+
| YEAR('98-02-03')YEARWEEK('1987-01-01')                  |
+---------------------------------------------------------+
| 198653                                                  |
+---------------------------------------------------------+
1 row in set (0.00 sec)

Note - सप्ताह संख्या अलग है क्या WEEK () फ़ंक्शन वैकल्पिक तर्कों के लिए 0 (1) लौटाएगा, जैसा कि WEEK () तब दिए गए वर्ष के संदर्भ में सप्ताह लौटाता है।