Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/postgresql/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 迄今为止的总额_Sql_Postgresql_Postgresql 11 - Fatal编程技术网

Sql 迄今为止的总额

Sql 迄今为止的总额,sql,postgresql,postgresql-11,Sql,Postgresql,Postgresql 11,我有一个包含以下数据的表格: 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 ...

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

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
但它错过了下个月的第一天。我想我需要调整
间隔部分。

例如:

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

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

编辑输入年份位,以便您可以在希望的情况下运行多年

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 )

嗯,我一直在考虑窗口功能,这似乎很简单。我将尝试使用subselects(因为我需要将其作为一个新列),并查看它的运行情况。谢谢。你只需要一笔钱吗?如果没有,则添加一些有问题的样本输出。仅针对2020年8月或所有月份?添加输出。好几个月了
date\u trunc('month',q.date)+interval'1 month'
会让您看到类似于
11/01/2020 00:00:00 PDT
的内容,它将错过
11/01/2020
上的所有时间戳
>00:00
。你需要做一些像“date\u trunc('month',q.date+interval'1 month')+interval'1 day'这样的事情,这会让你感觉像
11/02/2020 00:00:00 PST
。这将捕获
'11/01/2020'
@AdrianKlaver中的时间戳,捕捉得很好!谢谢你,保罗!注:我需要对月份和下个月的第一天求和。此外,date\u trunc(“月”,date\u字段)将是一种使这一行成为一行的方法!