QUARTER_FLOOR
描述
将日期时间值向下取整到最近的指定季度周期起点。如果指定了起始时间(origin),则以该时间为基准计算周期。
提示
QUARTER_FLOOR 支持从 3.0.8 和 3.1.0 版本开始。
语法
QUARTER_FLOOR(<datetime>)
QUARTER_FLOOR(<datetime>, <origin>)
QUARTER_FLOOR(<datetime>, <period>)
QUARTER_FLOOR(<datetime>, <period>, <origin>)
参数
参数 | 说明 |
---|---|
<datetime> | 需要向下取整的日期时间值,类型为 DATE 或 DATETIME |
<period> | 季度周期值,类型为 INT,表示每个周期包含的季度数 |
<origin> | 周期的起始时间点,类型为 DATE 或 DATETIME,默认值为 0001-01-01 00:00:00 |
注意:
- 不指定 period 时,等价于以 1 个季度为周期
- 当 period 不为正整数时,函数结果将为 NULL
- 结果总是向过去时间取整
- 返回值的时间部分总是 00:00:00
返回值
当 <datetime>
为 DATE 类型时,返回类型为 DATE。
当 <datetime>
为 DATETIME 类型时,返回类型为 DATETIME。
结果的时间部分将被设置为 00:00:00。
举例
从 '0001-01-01 00:00:00' 开始,每 5 / 4 个季度为一个周期,返回距离输入日期最近的周期起点。
SELECT QUARTER_FLOOR("2023-07-13 22:28:18", 5), QUARTER_FLOOR("2023-07-13 22:28:18", 4);
+-----------------------------------------+-----------------------------------------+
| QUARTER_FLOOR("2023-07-13 22:28:18", 5) | QUARTER_FLOOR("2023-07-13 22:28:18", 4) |
+-----------------------------------------+-----------------------------------------+
| 2023-07-01 00:00:00.000000 | 2023-01-01 00:00:00.000000 |
+-----------------------------------------+-----------------------------------------+
SELECT QUARTER_FLOOR("2023-07-13 22:28:18", 2, "2022-01-01 00:00:00"), QUARTER_FLOOR("2023-07-13 22:28:18", 4, "2022-01-01 00:00:00");
+----------------------------------------------------------------+----------------------------------------------------------------+
| QUARTER_FLOOR("2023-07-13 22:28:18", 2, "2022-01-01 00:00:00") | QUARTER_FLOOR("2023-07-13 22:28:18", 4, "2022-01-01 00:00:00") |
+----------------------------------------------------------------+----------------------------------------------------------------+
| 2023-07-01 00:00:00 | 2023-01-01 00:00:00 |
+----------------------------------------------------------------+----------------------------------------------------------------+
最佳实践
还可参阅 date_floor