QUARTERS_SUB
説明
QUARTERS_SUB関数は、指定された日時値に対して指定された四半期数(1四半期 = 3か月)を減算または加算し、計算された日時値を返すために使用されます。この関数はDATEおよびDATETIME型の処理をサポートします。負の数が入力された場合、対応する四半期数を加算することと同等です。
この関数は、QUARTERを単位として使用する場合、date_sub functionと一貫した動作をします。
構文
QUARTERS_SUB(`<date_or_time_expr>`, `<quarters>`)
パラメータ
| Parameter | デスクリプション |
|---|---|
<date_or_time_expr> | 入力される日付または日時の値。date/datetimeタイプをサポートします。具体的なdatetimeおよびdate形式については、datetime conversionおよびdate conversionを参照してください。 |
<quarters> | 加算または減算する四半期の数。正の整数は減算を、負の整数は加算を示します。 |
Return Value
入力日付タイプと一致する日付値を返します。
<quarters>が負の値の場合、この関数は対応する四半期数をベース時刻に加算するのと同じ動作をします(つまり、QUARTERS_SUB(date, -n)はQUARTERS_ADD(date, n)と同等です)。- 入力がDATEタイプ(年、月、日のみを含む)の場合、結果はDATEタイプのままです。入力がDATETIMEタイプの場合、結果は元の時刻コンポーネントを保持します(例:'2023-04-01 12:34:56'は1四半期減算後に'2023-01-01 12:34:56'になります)。
- 入力日付が月の最終日で、対象月がその日付より少ない日数しかない場合、対象月の最終日に自動的に調整されます(例:4月30日から1四半期(3ヶ月)減算すると1月31日になります)。
- 計算結果が日付タイプの有効範囲(DATEタイプ:0000-01-01から9999-12-31、DATETIMEタイプ:0000-01-01 00:00:00から9999-12-31 23:59:59)を超える場合、例外をスローします。
- いずれかのパラメータがNULLの場合、NULLを返します。
Examples
--- Subtract quarters from DATE type
SELECT QUARTERS_SUB('2020-01-31', 1) AS result;
+------------+
| result |
+------------+
| 2019-10-31 |
+------------+
--- Subtract quarters from DATETIME type (preserves time component)
SELECT QUARTERS_SUB('2020-01-31 02:02:02', 1) AS result;
+---------------------+
| result |
+---------------------+
| 2019-10-31 02:02:02 |
+---------------------+
--- Negative quarters (equivalent to addition)
SELECT QUARTERS_SUB('2019-10-31', -1) AS result;
+------------+
| result |
+------------+
| 2020-01-31 |
+------------+
--- Non-end-of-month date subtracting quarters (direct decrement)
SELECT QUARTERS_SUB('2023-07-13 22:28:18', 2) AS result;
+---------------------+
| result |
+---------------------+
| 2023-01-13 22:28:18 |
+---------------------+
--- DATETIME with microseconds (preserves precision)
SELECT QUARTERS_SUB('2023-10-13 22:28:18.456789', 1) AS result;
+----------------------------+
| result |
+----------------------------+
| 2023-07-13 22:28:18.456789 |
+----------------------------+
--- Subtracting quarters across years
SELECT QUARTERS_SUB('2024-04-01', 2) AS result;
+------------+
| result |
+------------+
| 2023-10-01 |
+------------+
--- Returns NULL when input is NULL
SELECT QUARTERS_SUB(NULL, 1), QUARTERS_SUB('2023-07-13', NULL) AS result;
+-------------------------+--------+
| quarters_sub(NULL, 1) | result |
+-------------------------+--------+
| NULL | NULL |
+-------------------------+--------+
--- Calculation result exceeds date range
SELECT QUARTERS_SUB('0000-04-30', 1) AS result;
ERROR 1105 (HY000): errCode = 2, detailMessage = (10.16.10.3)[E-218]Operation quarters_sub of 0000-04-30, 1 out of range
SELECT QUARTERS_SUB('9999-12-31', -1) AS result;
ERROR 1105 (HY000): errCode = 2, detailMessage = (10.16.10.3)[E-218]Operation quarters_sub of 9999-12-31, -1 out of range