gpt4 book ai didi

sql - generate_series() 表中的开始日期和结束日期

转载 作者:行者123 更新时间:2023-11-29 14:31:54 26 4
gpt4 key购买 nike

我正在尝试计算 PostgreSQL 中特定日期范围之间的工作日。

SELECT 
SUM(CASE WHEN extract (dow FROM foo) IN(1,2,3,4,5) THEN 1 ELSE 0
END)
FROM (SELECT ('2007-04-01'::date +
(generate_series(0,'2007-04-30'::date
- '2007-04-01'::date)||'days')::interval) AS foo) foo

我想用 start_dateend_date 替换名为 myTable 的表中的日期start_dateend_date 格式为 yyyy-mm-dd

实际上我需要它来显示每一行的工作日日期差异

|start_date |end_date |
------------------------
|2018-04-01 |2018-04-30|
|2018-05-01 |2018-05-30|

这是我的代码:

  SELECT pto.start_date, pto.end_date, 
SUM(CASE WHEN extract (dow FROM foo) IN(1,2,3,4,5) THEN 1 ELSE 0 END) as theDIFF
FROM (
SELECT start_date, (start_date::date +
(generate_series(0,end_date::date
- start_date::date)||'days')::interval) AS foo
FROM pto
) foo inner join pto pto
on pto.start_date = foo.start_date
group by pto.start_date, pto.end_date

我的输出:

  |start_date(date)| end_date(date) |theDiff(integer)
---------------------------------------------------
|2017-06-01 | 2017-06-01 | 29 |
|2017-05-29 | 2017-06-02 | 12 |
---------------------------------------------------

预期输出:

  |start_date(date)| end_date(date) |theDiff(integer)
---------------------------------------------------
|2017-06-01 | 2017-06-01 | 1 |
|2017-05-29 | 2017-06-02 | 5 |
---------------------------------------------------

最佳答案

您的示例代码有点困惑,因此仅考虑工作日和您的表格,这将给出预期的输出:

CREATE TABLE myTable (start_date date, end_date date);

INSERT INTO myTable VALUES('2017-06-01', '2017-06-01'),('2017-05-29', '2017-06-02');

SELECT start_date, end_date,
SUM(CASE WHEN EXTRACT(dow FROM days) BETWEEN 1 AND 5 THEN 1 ELSE 0 END)
FROM myTable
CROSS JOIN LATERAL generate_series(start_date, end_date, interval '1 day') AS days
GROUP BY start_date, end_date;

它将生成行,每一行都有 start_date、end_date 和它们之间的一天。然后它会按 start_date、end_date 和 SUM() 日期进行聚合,这些日期在 1 到 5 之间(周一至周五)。

没有聚合它看起来像这样:

 start_date |  end_date  |          days          | dow
------------+------------+------------------------+-----
2017-06-01 | 2017-06-01 | 2017-06-01 00:00:00+02 | 4
2017-05-29 | 2017-06-02 | 2017-05-29 00:00:00+02 | 1
2017-05-29 | 2017-06-02 | 2017-05-30 00:00:00+02 | 2
2017-05-29 | 2017-06-02 | 2017-05-31 00:00:00+02 | 3
2017-05-29 | 2017-06-02 | 2017-06-01 00:00:00+02 | 4
2017-05-29 | 2017-06-02 | 2017-06-02 00:00:00+02 | 5

分组依据:

 start_date |  end_date  | sum
------------+------------+-----
2017-06-01 | 2017-06-01 | 1
2017-05-29 | 2017-06-02 | 5

关于sql - generate_series() 表中的开始日期和结束日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50501924/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com