メインコンテンツまでスキップ

QUARTERS_SUB

説明

QUARTERS_SUB関数は、指定された日時値から指定された四半期数(1四半期 = 3ヶ月)を減算または加算し、計算された日時値を返すために使用されます。この関数はDATEとDATETIME型の処理をサポートします。負の数が入力された場合、対応する四半期数を加算することと同等です。この関数はDATE、DATETIMEおよびTIMESTAMPTZ入力型をサポートします。

この関数はQUARTERを単位として使用する場合、date_sub functionと一貫した動作をします。

構文

QUARTERS_SUB(`<date_or_time_expr>`, `<quarters>`)

パラメータ

パラメータ説明
<date_or_time_expr>入力日付または日時の値。date/datetime/timestamptz型をサポート。具体的なフォーマットについては、timestamptz conversiondatetime conversiondate conversionを参照してください。
<quarters>加算または減算する四半期の数。正の整数は減算を示し、負の整数は加算を示します。

戻り値

入力日付型と一致する日付値を返します。戻り値の型は最初のパラメータの型によって決定されます:

  • <quarters>が負の場合、この関数は基準時間に対応する四半期数を加算するのと同じ動作をします(つまり、QUARTERS_SUB(date, -n)はQUARTERS_ADD(date, n)と等価です)。
  • 入力がDATE型(年、月、日のみを含む)の場合、結果はDATE型になります。入力がDATETIME型の場合、結果はDATETIME型になり、元の時刻コンポーネントが保持されます(例:'2023-04-01 12:34:56'は1四半期を減算すると'2023-01-01 12:34:56'になります)。
  • 入力がTIMESTAMPTZ型の場合、戻り値はTIMESTAMPTZ型になります(日付、時刻、タイムゾーンオフセットを含む)。
  • 入力日付が月の最終日で、対象月がその日付より少ない日数しかない場合、対象月の最終日に自動的に調整されます(例: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を返します。

--- 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 |
+-------------------------+--------+

--- Example of TimeStampTz type, SET time_zone = '+08:00'
SELECT QUARTERS_SUB('2025-10-10 11:22:33.123+07:00', 1);
+--------------------------------------------------+
| QUARTERS_SUB('2025-10-10 11:22:33.123+07:00', 1) |
+--------------------------------------------------+
| 2025-07-10 12:22:33.123+08:00 |
+--------------------------------------------------+

--- 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