如何解决PostgreSQL - 跨年获得一致的年周对
我一直在寻找在 PostrgeSQL 中检索一致(年、周)对的解决方案。
在查看问题 here 之后,特别是在 this comment:
按 date_part('year',x),date_part('week',x) 分组最有可能 不是用户想要的,应该被认为是不正确的。为了 例如,2017 年的第一天仍然是第 52 周的一部分 2016 年,因此 (2017,52) 对可能根本不是你想要的 想要,因为它排序到 2017 年底。使用 'date_trunc('week',x)` 另一只手按预期工作。
我尝试了 date_trunc
和 date_part
的某种组合。然而,似乎没有一个给出一致的结果。
例如:考虑不同年份之间的这两个日期:'2017-01-01'
和 '2020-01-01'
。
我认为它们的正确(年、周)对应该是 (2016,52)
和 (2020,1)
。
我不知道如何编写一个会给出这两个结果的 SQL 语句。
我试过了:
1.
SELECT date_part('year',date_trunc('week',TIMESTAMP '2017-01-01 00:00:00')); --2016 OK
SELECT date_part('week',TIMESTAMP '2017-01-01 00:00:00')); --52 OK
SELECT date_part('year',TIMESTAMP '2020-01-01 00:00:00')); --2019 BUT I NEED 2020
SELECT date_part('week',TIMESTAMP '2020-01-01 00:00:00')); --1 OK
SELECT date_part('year',TIMESTAMP '2017-01-01 00:00:00'); --2017 BUT I NEED 2016
SELECT date_part('week',TIMESTAMP '2017-01-01 00:00:00'); --52 OK
SELECT date_part('year',TIMESTAMP '2020-01-01 00:00:00'); --2020 OK
SELECT date_part('week',TIMESTAMP '2020-01-01 00:00:00'); --1 OK
无论哪种方式,总会有一些错误,我可能想要一些可以给出正确结果的东西。我的问题是,当我按年和周分组时,这样有时我会考虑超过 7 天,我需要避免这种情况。
解决方法
week
单位返回基于 ISO 标准的周数。要获得相同的年份,请使用 isoyear
SELECT date_part('isoyear',TIMESTAMP '2017-01-01 00:00:00'),date_part('week',date_part('isoyear',TIMESTAMP '2020-01-01 00:00:00'),TIMESTAMP '2020-01-01 00:00:00');
返回:
date_part | date_part | date_part | date_part
----------+-----------+-----------+----------
2016 | 52 | 2020 | 1
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。