在尝试按一年中的一周分组时,我发现 12 月 31 日在 Postgres 中返回的一年中的一周因意外结果而异(至少对我而言)。结果通常是 52(好),有时是 53,通常是 1。
53 我可以理解,因为它是根据一周中的特定日期计算周数的,所以按那一天计算可能会得到 53 周。不是很好,但可以理解。
但是为什么 Postgres 经常说 12 月 31 日是一年的第一周呢?这有什么意义?
例子:
SELECT EXTRACT(WEEK FROM DATE '2000-12-31') AS "Week",'Week2000' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2001-12-31') AS "Week",'Week2001' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2002-12-31') AS "Week",'Week2002' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2003-12-31') AS "Week",'Week2003' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2004-12-31') AS "Week",'Week2004' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2005-12-31') AS "Week",'Week2005' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2006-12-31') AS "Week",'Week2006' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2007-12-31') AS "Week",'Week2007' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2008-12-31') AS "Week",'Week2008' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2009-12-31') AS "Week",'Week2009' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2010-12-31') AS "Week",'Week2010' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2011-12-31') AS "Week",'Week2011' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2012-12-31') AS "Week",'Week2012' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2013-12-31') AS "Week",'Week2013' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2014-12-31') AS "Week",'Week2014' AS "Year"
UNION SELECT EXTRACT(WEEK FROM DATE '2015-12-31') AS "Week",'Week2015' AS "Year"
ORDER BY "Year"
Run Code Online (Sandbox Code Playgroud)
结果:
Week Year
----- ---------
52 Week2000
1 Week2001
1 Week2002
1 Week2003
53 Week2004
52 Week2005
52 Week2006
1 Week2007
1 Week2008
53 Week2009
52 Week2010
52 Week2011
1 Week2012
1 Week2013
1 Week2014
53 Week2015
Run Code Online (Sandbox Code Playgroud)
我已经通过指定完整的时间戳而不仅仅是日期进行了测试,并且无论我在时间戳中包含一天中的哪个小时都具有相同的结果。
12 月 29 日和 30 日也可能产生 1、52 或 53 个结果。
12 月 27 日和 28 日可能是 52 或 53。
PostgreSQL 使用 ISO8601 定义。这意味着周从星期一开始,一年中的第一周是有 1 月 4 日的那一周。例如,如果 1 月 4 日是星期二,那么 12 月 31 日就是该年的第 1 周。
| 归档时间: |
|
| 查看次数: |
872 次 |
| 最近记录: |