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

MONTHS_ADD

説明

MONTHS_ADD関数は、入力されたdatetime値に指定された月数を加算し、結果として新しいdatetime値を返します。この関数は、DATE、DATETIME、およびTIMESTAMPTZ型の処理をサポートします。負の数が入力された場合、対応する月数を減算することと同等です。

この関数は、MONTHを単位として使用する場合、date_add functionおよびMySQLのdate_add functionと一致します。

構文

MONTHS_ADD(`<date_or_time_expr>`, `<nums>`)

パラメータ

パラメータ説明
<date_or_time_expr>入力される日時値。date/datetime/timestamptz型をサポート。具体的な形式については、timestamptz conversiondatetime conversiondate conversionを参照してください。
<nums>加算または減算する月数。INT型。負の数値は日時からnums月を減算することを示し、正の数値はnums月を加算することを示します。

戻り値

入力された<date_or_time_expr>と同じ型の値(DATE、DATETIME、またはTIMESTAMPTZ)を返し、基準時刻に指定された月数を加算した結果を表します。

  • <nums>が負の場合、基準時刻から対応する月数を減算する動作と同じになります(つまり、MONTHS_ADD(date, -n)はMONTHS_SUB(date, n)と同等です)。
  • 入力日付が月の最終日で、対象月がその日付よりも少ない日数の場合、自動的に対象月の最終日に調整されます(例:1月31日に1か月を加算すると、うるう年かどうかに応じて2月28日または29日になります)。
  • 計算結果が日付型の有効範囲を超える場合(DATE型:0000-01-01から9999-12-31、DATETIME型:0000-01-01 00:00:00から9999-12-31 23:59:59)、エラーを返します。
  • いずれかのパラメータがNULLの場合、NULLを返します。

-- Add months to DATE type
SELECT MONTHS_ADD('2020-01-31', 1) AS result;
+------------+
| result |
+------------+
| 2020-02-29 |
+------------+

-- Add months to DATETIME type (preserves time component)
SELECT MONTHS_ADD('2020-01-31 02:02:02', 1) AS result;
+---------------------+
| result |
+---------------------+
| 2020-02-29 02:02:02 |
+---------------------+

-- Negative months (equivalent to subtraction)
SELECT MONTHS_ADD('2020-01-31', -1) AS result;
+------------+
| result |
+------------+
| 2019-12-31 |
+------------+

-- Non-end-of-month date adding months (direct accumulation)
SELECT MONTHS_ADD('2023-07-13 22:28:18', 5) AS result;
+---------------------+
| result |
+---------------------+
| 2023-12-13 22:28:18 |
+---------------------+

-- DATETIME with microseconds (preserves precision)
SELECT MONTHS_ADD('2023-07-13 22:28:18.456789', 3) AS result;
+----------------------------+
| result |
+----------------------------+
| 2023-10-13 22:28:18.456789 |
+----------------------------+

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

-- Returns NULL when input is NULL
SELECT MONTHS_ADD(NULL, 5), MONTHS_ADD('2023-07-13', NULL) AS result;
+----------------------+--------+
| months_add(NULL, 5) | result |
+----------------------+--------+
| NULL | NULL |
+----------------------+--------+

-- Calculation result exceeds date range
SELECT MONTHS_ADD('9999-12-31', 1) AS result;
ERROR 1105 (HY000): errCode = 2, detailMessage = (10.16.10.3)[E-218]Operation months_add of 9999-12-31, 1 out of range

SELECT MONTHS_ADD('0000-01-01', -1) AS result;
ERROR 1105 (HY000): errCode = 2, detailMessage = (10.16.10.3)[E-218]Operation months_add of 0000-01-01, -1 out of range