如何解决迄今为止的总和
我有一张包含此数据的表:
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(含),并且该值在开始期间的所有天内都列在该列中(在本例中为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';
,
这将每月为您带来价值。将表名称替换为your_table,将日期名称替换为your_date_field。
EDIT (输入年份),以便您可以根据需要将此年份运行多年。
5)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。