从日期到日期的总和



我有一个包含以下数据的表:

Date        Value
...
2020-07-30  0.0
2020-07-31  12527.922
2020-08-01  29983.598
2020-08-02  34333.74
2020-08-03  33550.0
...
2020-08-30  22722.02
2020-08-31  21376.416
2020-09-01  23762.43
2020-09-02  16267.47
2020-09-03  25241.0
...

我需要从每月的第一天到下一个月的第一天进行汇总(包括(。即,从2020-08-01到2020-09-01(包括2020-08-001(,该值在开始期的所有日子都在一列中(在本例中为08(,有什么想法吗?谢谢

预期输出:

Date        Value      Period_Sum
...
2020-07-30  0          sum of 2020-07-01 to 2020-08-01
2020-07-31  1          ...
2020-08-01  2          sum of 2020-08-01 to 2020-09-01
2020-08-02  3          ...
2020-08-03  3          ...
...
2020-08-30  2          ...
2020-08-31  2          ...
2020-09-01  2          sum of 2020-09-01 to 2020-10-01
2020-09-02  1          ...
2020-09-03  2          ...
...

根据Adrian的回复,我正在尝试使用子选择,如:

select
(
select
sum(qq.value)
from
data_table qq
where
qq.date between date_trunc('month', q.date)
and date_trunc('month', q.date) + interval '1 month'
) period_sum
, date
, value
from
data_table q

但它错过了下个月的第一天。我想我需要调整interval部分。

例如:

SELECT 
SUM(VALUE)
FROM
some_table
WHERE 
Date BETWEEN '2020-08-01' AND '2020-09-01';

这将为您每月提供一个值。将您的table换成表名,将您的_date_field换成日期字段。

编辑输入年份位,这样您就可以在需要时运行多年。

SELECT 
SUM(VALUE), 
date_part('month', your_date_field ), 
date_part('year', your_date_field )
FROM
your_table
GROUP BY 
date_part('month', your_date_field ),
date_part('year', your_date_field )

相关内容

  • 没有找到相关文章

最新更新