跳到主要内容

QUARTERS_ADD

描述

QUARTERS_ADD 函数用于在指定的日期时间值基础上增加或减少指定的季度数(1 个季度 = 3 个月),并返回计算后的日期时间值。该函数支持处理 DATE、DATETIME 类型,若输入负数则等效于减去对应季度数。

该函数与 date_add 函数 使用 QUARTER 为单位行为一致。

语法

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

参数

参数说明
<date_or_time_expr>输入的日期或日期时间值,支持输入 date/datetime 类型,具体 datetime 和 date 格式请查看 datetime 的转换date 的转换
<quarters>要增加或减少的季度数,正整数表示增加,负整数表示减少。

返回值

返回一个日期值,与输入的日期类型一致。

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

举例

--- 向 DATE 类型添加季度
SELECT QUARTERS_ADD('2020-01-31', 1) AS result;
+------------+
| result |
+------------+
| 2020-04-30 |
+------------+

--- 向 DATETIME 类型添加季度(保留时间部分)
SELECT QUARTERS_ADD('2020-01-31 02:02:02', 1) AS result;
+---------------------+
| result |
+---------------------+
| 2020-04-30 02:02:02 |
+---------------------+

--- 负数季度(等价于减法)
SELECT QUARTERS_ADD('2020-04-30', -1) AS result;
+------------+
| result |
+------------+
| 2020-01-30 |
+------------+

--- 非月底日期添加季度(直接累加)
SELECT QUARTERS_ADD('2023-07-13 22:28:18', 2) AS result;
+---------------------+
| result |
+---------------------+
| 2024-01-13 22:28:18 |
+---------------------+

--- 包含微秒的 DATETIME(保留精度)
SELECT QUARTERS_ADD('2023-07-13 22:28:18.456789', 1) AS result;
+----------------------------+
| result |
+----------------------------+
| 2023-10-13 22:28:18.456789 |
+----------------------------+

--- 跨年度添加季度
SELECT QUARTERS_ADD('2023-10-01', 2) AS result;
+------------+
| result |
+------------+
| 2024-04-01 |
+------------+

--- 输入为 NULL 时返回 NULL
SELECT QUARTERS_ADD(NULL, 1), QUARTERS_ADD('2023-07-13', NULL) AS result;
+-------------------------+--------+
| quarters_add(NULL, 1) | result |
+-------------------------+--------+
| NULL | NULL |
+-------------------------+--------+

--- 计算结果超出日期范围
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