MySQL WEEK() 函数使用指南
MySQL WEEK() 函数返回给定日期位于当年的第几周。
WEEK() 语法
这是 MySQL WEEK() 函数的语法:
WEEK(date)
WEEK(date, mode)
参数
date- 必需的。一个日期或者日期时间表达式。
mode- 可选的。确定计算周的逻辑。如果没有指定该参数,默认将使用
default_week_format变量的值。
返回值
MySQL WEEK() 函数返回给定日期位于当年的第几周,取值范围为 0 到 53。
下表整理了 WEEK() 函数对 mode 参数的处理逻辑:
| Mode | 每周的第一天 | 返回值范围 | 对第一周的要求 |
|---|---|---|---|
0 |
星期天 | 0-53 |
|
1 |
星期一 | 0-53 |
在本年至少 4 天 |
2 |
星期天 | 1-53 |
|
3 |
星期一 | 1-53 |
在本年至少 4 天 |
4 |
星期天 | 0-53 |
在本年至少 4 天 |
5 |
星期一 | 0-53 |
|
6 |
星期天 | 1-53 |
在本年至少 4 天 |
7 |
星期一 | 1-53 |
- 如果指定的表达式不是一个合法的日期或者日期时间,
WEEK()函数将返回NULL。 - 如果参数为
NULL,WEEK()函数将返回NULL。
WEEK() 示例
这里是几个 WEEK() 函数的示例。
SELECT
WEEK('2022-01-01', 0),
WEEK('2022-01-03', 0),
WEEK('2022-01-01', 1),
WEEK('2022-01-03', 1),
WEEK('2022-01-01', 2),
WEEK('2022-01-03', 2),
WEEK('2022-01-01', 3),
WEEK('2022-01-03', 3),
WEEK('2022-01-01', 4),
WEEK('2022-01-03', 4),
WEEK('2022-01-01', 5),
WEEK('2022-01-03', 5),
WEEK('2022-01-01', 6),
WEEK('2022-01-03', 6),
WEEK('2022-01-01', 7),
WEEK('2022-01-03', 7)\G
WEEK('2022-01-01', 0): 0
WEEK('2022-01-03', 0): 1
WEEK('2022-01-01', 1): 0
WEEK('2022-01-03', 1): 1
WEEK('2022-01-01', 2): 52
WEEK('2022-01-03', 2): 1
WEEK('2022-01-01', 3): 52
WEEK('2022-01-03', 3): 1
WEEK('2022-01-01', 4): 0
WEEK('2022-01-03', 4): 1
WEEK('2022-01-01', 5): 0
WEEK('2022-01-03', 5): 1
WEEK('2022-01-01', 6): 52
WEEK('2022-01-03', 6): 1
WEEK('2022-01-01', 7): 52
WEEK('2022-01-03', 7): 1