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

MySQL में TIMEDIFF () बनाम SUBTIME ():क्या अंतर है?

आपने देखा होगा कि MySQL में एक TIMEDIFF() है फ़ंक्शन और एक SUBTIME() समारोह। और आपने देखा होगा कि कई मामलों में, वे दोनों एक ही परिणाम देते हैं। तो आप सोच रहे होंगे कि इन दोनों फंक्शन में क्या अंतर है?

आइए जानें।

सिंटैक्स

आइए पहले प्रत्येक फ़ंक्शन के सिंटैक्स को देखें।

सबटाइम ()

SUBTIME(expr1,expr2)

जहां expr1 एक समय या डेटाटाइम अभिव्यक्ति है, और expr2 एक समय अभिव्यक्ति है।

TIMEDIFF ()

TIMEDIFF(expr1,expr2)

जहां expr1 और expr2 समय या दिनांक और समय के भाव हैं, लेकिन दोनों एक ही प्रकार के होने चाहिए।

अंतर

तो ये है अंतर:

  • SUBTIME() का उपयोग करते समय , दूसरा तर्क एक समय अभिव्यक्ति होना चाहिए
  • TIMEDIFF() का उपयोग करते समय दूसरा तर्क या तो समय या दिनांक और समय का व्यंजक हो सकता है, लेकिन किसी भी स्थिति में, यह पहले व्यंजक के समान प्रकार का होना चाहिए

उदाहरण 1 - दोनों तर्क 'समय' मान हैं

यहां दोनों फ़ंक्शन की तुलना की गई है, जहां दोनों तर्क समय मान हैं।

SELECT 
    TIMEDIFF('11:35:25', '10:35:25') AS 'TIMEDIFF',
    SUBTIME('11:35:25', '10:35:25') AS 'SUBTIME';

परिणाम:

+----------+----------+
| TIMEDIFF | SUBTIME  |
+----------+----------+
| 01:00:00 | 01:00:00 |
+----------+----------+

जैसा कि अपेक्षित था, दोनों फ़ंक्शन एक ही परिणाम देते हैं।

उदाहरण 2 - दोनों तर्क 'डेटाटाइम' मान हैं

यहां दोनों फ़ंक्शन की तुलना की गई है, जहां दोनों तर्क डेटाटाइम मान हैं।

SELECT 
    TIMEDIFF('2021-02-01 10:35:25', '2021-01-01 10:35:25') AS 'TIMEDIFF',
    SUBTIME('2021-02-01 10:35:25', '2021-01-01 10:35:25') AS 'SUBTIME';

परिणाम:

+-----------+---------+
| TIMEDIFF  | SUBTIME |
+-----------+---------+
| 744:00:00 | NULL    |
+-----------+---------+

इस मामले में, SUBTIME() एक शून्य मान लौटाया क्योंकि इसका दूसरा तर्क समय मान नहीं था (यह एक डेटाटाइम मान था)।

उदाहरण 3 - पहला तर्क 'डेटाटाइम' है, दूसरा 'समय' है

यहां, पहला तर्क डेटाटाइम मान है। दूसरा तर्क एक समय मान है।

SELECT 
    TIMEDIFF('2021-02-01 10:35:25', '09:35:25') AS 'TIMEDIFF',
    SUBTIME('2021-02-01 10:35:25', '09:35:25') AS 'SUBTIME';

परिणाम:

+----------+---------------------+
| TIMEDIFF | SUBTIME             |
+----------+---------------------+
| NULL     | 2021-02-01 01:00:00 |
+----------+---------------------+

इस मामले में, TIMEDIFF() एक शून्य मान लौटाया क्योंकि दोनों तर्क एक अलग प्रकार के थे।

उदाहरण 4 - पहला तर्क 'समय' है, दूसरा 'डेटाटाइम' है

और यहाँ, हम इसे चारों ओर स्वैप करते हैं। पहला तर्क एक समय मान है। दूसरा तर्क डेटाटाइम मान है।

SELECT 
    TIMEDIFF('09:35:25', '2021-01-01 10:35:25') AS 'TIMEDIFF',
    SUBTIME('09:35:25', '2021-01-01 10:35:25') AS 'SUBTIME';

परिणाम:

+----------+---------+
| TIMEDIFF | SUBTIME |
+----------+---------+
| NULL     | NULL    |
+----------+---------+

इस मामले में:

  • TIMEDIFF() एक शून्य मान लौटाया क्योंकि दोनों तर्क एक अलग प्रकार के थे।
    SUBTIME() एक शून्य मान लौटाया क्योंकि यह केवल अपने दूसरे तर्क के लिए एक समय मान स्वीकार करता है।

  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. मैं MySQL के ORDER BY RAND () फ़ंक्शन को कैसे अनुकूलित कर सकता हूं?

  2. MySQL डेटाबेस परिनियोजन स्वचालन

  3. MySQL बनाम पीडीओ

  4. मैं MySQL में चालू माह के पहले दिन और वर्तमान दिन के बीच कैसे चयन करूं?

  5. MySQL CONCAT शर्त के साथ चयन करें