メインコンテンツまでスキップ
バージョン: 26.x

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