首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在一次查询中得到一天和最后三天的和?

如何在一次查询中得到一天和最后三天的和?
EN

Stack Overflow用户
提问于 2016-03-14 12:17:37
回答 2查看 2.1K关注 0票数 3

假设我有这样一个统计表:

代码语言:javascript
复制
date | stats
-------------
10/1 | 2
10/1 | 3
10/1 | 2
10/2 | 1
10/3 | 3
10/3 | 2
10/4 | 1
10/4 | 1

我想要的是三栏:

  1. 日期
  2. 日期总额(统计)
  3. 日期前三天的总和(统计数字)

我知道我可以使用窗口函数来处理第二列,但我不能同时处理第二列和第三列。

我该怎么做才能把这个存档?

谢谢!

EN

回答 2

Stack Overflow用户

发布于 2016-03-14 12:19:52

您可以使用聚合和窗口函数:

代码语言:javascript
复制
select date, sum(stats) as day_stats,
       sum(sum(stats)) over (order by date rows between 3 preceding and 1 preceding) as day_stats_3
from t
group by date
order by date;
票数 5
EN

Stack Overflow用户

发布于 2016-03-14 12:20:54

您可以使用相关查询:

代码语言:javascript
复制
SELECT s.date,sum(s.stats) as today_sum,
       (SELECT sum(t.stats) FROM YourTable t
        where t.date between s.date - 2 and s.date) as sum_3days
FROM YourTable s
GROUP BY s.date
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35987348

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档