秒
説明
SECOND関数は、指定された日時値から秒の部分を抽出し、0から59までの整数結果を返します。この関数は、DATE、DATETIME、およびTIME型の処理をサポートします。
この関数は、MySQLのsecond functionと一致しています。
構文
SECOND(<date_or_time_expr>)
パラメータ
| パラメータ | 説明 |
|---|---|
<date_or_time_expr> | 入力datetime値。DATE、DATETIME、またはTIME型を指定できます。特定のdatetime/date/time形式については、datetime conversionとdate conversion、time conversionを参照してください。 |
戻り値
入力datetimeの秒部分を表すINT型の値を返します:
- 範囲:0から59(境界値を含む)
- 入力がDATE型の場合、0を返します(デフォルト時刻が00:00:00のため)
- 入力がNULLの場合、NULLを返します
- マイクロ秒部分は無視します(例:12:34:56.789では56秒のみを抽出)
例
-- Extract seconds from DATETIME
SELECT SECOND('2018-12-31 23:59:59') AS result;
+--------+
| result |
+--------+
| 59 |
+--------+
-- Input is TIME type
SELECT SECOND(cast('15:42:33' as time)) AS result;
+--------+
| result |
+--------+
| 33 |
+--------+
-- Input is DATE type (default seconds is 0)
SELECT SECOND('2023-07-13') AS result;
+--------+
| result |
+--------+
| 0 |
+--------+
-- Time with microseconds (ignores microseconds)
SELECT SECOND('2023-07-13 10:30:25.123456') AS result;
+--------+
| result |
+--------+
| 25 |
+--------+
-- Case where seconds is 0
SELECT SECOND('2024-01-01 00:00:00') AS result;
+--------+
| result |
+--------+
| 0 |
+--------+
-- When a string literal is valid for both datetime and time, prefer parsing it as time
SELECT SECOND("22:12:12");
+--------------------+
| SECOND("22:12:12") |
+--------------------+
| 12 |
+--------------------+
-- Input is NULL (returns NULL)
SELECT SECOND(NULL) AS result;
+--------+
| result |
+--------+
| NULL |
+--------+