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