HOURS_SUB
説明
HOURS_SUB関数は、入力された日付またはdatetimeの値から指定された時間数を減算し、計算された新しいdatetimeを返します。この関数はDATEとDATETIMEの両方の入力タイプをサポートしています。入力がDATEタイプ(年、月、日のみを含む)の場合、時刻部分はデフォルトで00:00:00になります。
この関数は、HOUR単位を使用する場合のdate_sub functionおよびMySQLのdate_sub functionと一致しています。
構文
HOURS_SUB(`<date_or_time_expr>`, `<hours>`)
パラメータ
| Parameter | デスクリプション |
|---|---|
<date_or_time_expr> | date/datetimeタイプをサポートする有効な日付式。具体的なdatetimeおよびdate形式については、datetime conversionおよびdate conversionを参照してください |
<hours> | 減算する時間数。INT型 |
戻り値
指定された時間数を加算または減算した後のdatetimeを表すDATETIME型の値を返します(形式:YYYY-MM-DD HH:MM:SS)。
- 計算結果がDATETIME型の有効範囲(0000-01-01 00:00:00から9999-12-31 23:59:59)を超える場合、エラーを返します。
- 入力パラメータがNULLの場合、NULLを返します。
- 入力時間数が負の場合、対応する時間数を加算したdatetimeを返します。
Examples
-- Subtract positive hours
SELECT HOURS_SUB('2020-02-02 02:02:02', 1);
+------------------------------------------------------------+
| hours_sub(cast('2020-02-02 02:02:02' as DATETIMEV2(0)), 1) |
+------------------------------------------------------------+
| 2020-02-02 01:02:02 |
+------------------------------------------------------------+
-- Subtract hours from date type
select hours_sub('2023-10-01', 12);
+-----------------------------+
| hours_sub('2023-10-01', 12) |
+-----------------------------+
| 2023-09-30 12:00:00 |
+-----------------------------+
-- Input hours is negative, returns datetime plus hours
select hours_sub('2023-10-01 10:00:00', -3);
+--------------------------------------+
| hours_sub('2023-10-01 10:00:00', -3) |
+--------------------------------------+
| 2023-10-01 13:00:00 |
+--------------------------------------+
-- Any parameter is NULL, return NULL
select hours_sub('2023-10-01 10:00:00', NULL);
+----------------------------------------+
| hours_sub('2023-10-01 10:00:00', NULL) |
+----------------------------------------+
| NULL |
+----------------------------------------+
-- Exceeds datetime range, return NULL
mysql> select hours_sub('9999-12-31 12:00:00', -20);
ERROR 1105 (HY000): errCode = 2, detailMessage = (10.16.10.2)[E-218]Operation hours_add of 9999-12-31 12:00:00, 20 out of range
mysql> select hours_sub('0000-01-01 12:00:00', 20);
ERROR 1105 (HY000): errCode = 2, detailMessage = (10.16.10.2)[E-218]Operation hours_add of 0000-01-01 12:00:00, -20 out of range