迄今为止的总和

问题描述

我有一张包含此数据的表:

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)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...