YEAR_FLOOR
説明
year_floor関数は、入力されたdatetime値を指定された年間隔の開始時刻に切り下げます。originが指定された場合はそれを基準として使用し、そうでなければデフォルトで0000-01-01 00:00:00を使用します。
日付計算式: $$ \begin{aligned} &\text{year_floor}(\langle\text{date_or_time_expr}\rangle, \langle\text{period}\rangle, \langle\text{origin}\rangle) = \ &\max{\langle\text{origin}\rangle + k \times \langle\text{period}\rangle \times \text{year} \mid \ &k \in \mathbb{Z} \land \langle\text{origin}\rangle + k \times \langle\text{period}\rangle \times \text{year} \leq \langle\text{date_or_time_expr}\rangle} \end{aligned} $$ $k$は基準時刻から対象時刻までの期間数を表します。
構文
YEAR_FLOOR(<date_or_time_expr>)
YEAR_FLOOR(<date_or_time_expr>, origin)
YEAR_FLOOR(<date_or_time_expr>, <period>)
YEAR_FLOOR(<date_or_time_expr>, <period>, <origin>)
パラメータ
| Parameter | デスクリプション |
|---|---|
<date_or_time_expr> | 切り下げする日時の値。date/datetimeタイプをサポートします。datetimeおよびdateの形式については、datetime conversionとdate conversionを参照してください |
<period> | オプション。各期間が何秒で構成されるかを表します。正の整数タイプ(INT)をサポートします。デフォルトは1秒です。 |
<origin_datetime> | 間隔の開始点。date/datetimeタイプをサポートします。デフォルトは0000-01-01 00:00:00です。 |
Return Value
入力タイプと一致する結果(DATETIMEまたはDATE)を返し、切り下げ後の年間隔開始時刻を表します:
- 入力がDATEタイプの場合、DATETYPEを返します(日付部分のみ含む)。入力がDATETIMEまたは適切にフォーマットされた文字列の場合、DATETIMEタイプを返します(時刻部分はoriginと一致し、originがない場合はデフォルトで00:00:00)。
<period>が非正の整数(≤0)の場合、関数はエラーを返します。- いずれかのパラメータがNULLの場合、NULLを返します。
<date_or_time_expr>が間隔の開始点と正確に一致する場合(<period>と<origin>に基づく)、その開始点を返します。- 計算結果が最大日時9999-12-31 23:59:59を超える場合、エラーを返します。
<origin>の日時が<period>より後の場合でも、上記の式に従って計算されますが、期間kは負の値になります。- date_or_time_exprにスケールがある場合、返される結果にもスケールがあり、小数部分はゼロになります。
Examples
-- Default 1-year interval (start point is January 1st each year), 2023-07-13 rounds down to 2023-01-01
SELECT YEAR_FLOOR('2023-07-13 22:28:18') AS result;
+---------------------+
| result |
+---------------------+
| 2023-01-01 00:00:00 |
+---------------------+
-- Specify 5-year interval, 2023-07-13 rounds down to nearest 5-year interval start (calculated with default origin)
SELECT YEAR_FLOOR('2023-07-13 22:28:18', 5) AS result;
+---------------------+
| result |
+---------------------+
| 2020-01-01 00:00:00 |
+---------------------+
-- input with scale
mysql> SELECT YEAR_FLOOR('2023-07-13 22:28:18.123', 5) AS result;
+-------------------------+
| result |
+-------------------------+
| 2021-01-01 00:00:00.000 |
+-------------------------+
-- Input is DATE type, returns DATE type interval start
SELECT YEAR_FLOOR(cast('2023-07-13' as date)) AS result;
+------------+
| result |
+------------+
| 2023-01-01 |
+------------+
-- Only with origin date and specified date
select year_floor("2023-07-13 22:28:18", "2021-03-13 22:13:00");
+----------------------------------------------------------+
| year_floor("2023-07-13 22:28:18", "2021-03-13 22:13:00") |
+----------------------------------------------------------+
| 2023-03-13 22:13:00 |
+----------------------------------------------------------+
-- Specify origin reference point='2020-01-01', 1-year interval, 2023-07-13 rounds to 2023-01-01
SELECT YEAR_FLOOR('2023-07-13', 1, '2020-01-01') AS result;
+---------------------+
| result |
+---------------------+
| 2023-01-01 00:00:00 |
+---------------------+
-- Specify origin with time part, returned result's time part matches origin
SELECT YEAR_FLOOR('2023-07-13', 1, '2020-01-01 08:30:00') AS result;
+---------------------+
| result |
+---------------------+
| 2023-01-01 08:30:00 |
+---------------------+
-- Input exactly at interval start point (origin='2023-01-01', period=1), returns itself
SELECT YEAR_FLOOR('2023-01-01', 1, '2023-01-01') AS result;
+---------------------+
| result |
+---------------------+
| 2023-01-01 00:00:00 |
+---------------------+
-- Input time earlier than origin start time, rounds down to earlier interval point
SELECT YEAR_FLOOR('2019-07-13', 1, '2020-01-01') AS result;
+---------------------+
| result |
+---------------------+
| 2019-01-01 00:00:00 |
+---------------------+
-- Cross-multiple periods rounding down, period=3, origin='2020-01-01'
SELECT YEAR_FLOOR('2025-07-13', 3, '2020-01-01') AS result;
+---------------------+
| result |
+---------------------+
| 2023-01-01 00:00:00 |
+---------------------+
-- If the <origin> date and time is after the <period>, it will still be calculated according to the above formula, but the period k will be negative.
SELECT YEAR_FLOOR('2023-07-13 22:22:56', 1, '2028-01-01 08:30:00') AS result;
+---------------------+
| result |
+---------------------+
| 2023-01-01 08:30:00 |
+---------------------+
-- Input time part earlier than origin time part, rounds down within same year
SELECT YEAR_FLOOR('2023-07-13 06:00:00', 1, '2020-01-01 08:30:00') AS result;
+---------------------+
| result |
+---------------------+
| 2022-01-01 08:30:00 |
+---------------------+
-- Input time part later than origin time part, normal rounding down
SELECT YEAR_FLOOR('2023-07-13 10:00:00', 1, '2020-01-01 08:30:00') AS result;
+---------------------+
| result |
+---------------------+
| 2023-01-01 08:30:00 |
+---------------------+
-- Invalid period (non-positive integer)
SELECT YEAR_FLOOR('2023-07-13', 0) AS result;
ERROR 1105 (HY000): errCode = 2, detailMessage = (10.16.10.3)[E-218]Operation year_floor of 2023-07-13 00:00:00, 0 out of range
-- Any parameter is NULL, returns NULL
SELECT YEAR_FLOOR(NULL, 1) AS result;
+--------+
| result |
+--------+
| NULL |
+--------+