首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用sql窗口函数求和最近n天的数量

使用sql窗口函数求和最近n天的数量
EN

Stack Overflow用户
提问于 2019-12-09 20:55:40
回答 2查看 808关注 0票数 0

我试图在Alteryx中创建以下逻辑,数据来自Exasol数据库。

“Sum_Qty_28_days”栏应汇总过去28天内同一篇文章的“数量”栏的值。

我的示例数据如下所示:

我想要以下输出:

例如。“文章”=‘A’和date =‘’2019-10-8“的”Sum_Qty_28_days“值是8,因为它汇总了与日期(在前28天内)相关联的”Sum_Qty_28_days“值: 2019-09-15 2019-10-05 2019-10-05 2019-10-08表示”文章“=‘A’。

使用SQL窗口函数可以做到这点吗?我用下面的代码试了试:

代码语言:javascript
复制
SUM("Qty") OVER (PARTITION BY "article", date_trunc('month',"Date")
             ORDER BY "Date")

但是,这远远不是我所需要的。汇总当月日期的数量。但是,我需要过去28天的数量总和。

提前谢谢。

EN

回答 2

Stack Overflow用户

发布于 2019-12-09 20:57:55

是的,在许多数据库中使用标准SQL都可以做到这一点。但是,这并不适用于所有数据库:

代码语言:javascript
复制
select t.*,
       sum(qty) over (partition by article
                      order by date
                      range between interval '27 day' preceding and current row
                     ) as sum_qty_28_days
from t;
票数 1
EN

Stack Overflow用户

发布于 2019-12-09 21:10:05

如果您的RDBMS不支持range框架,另一种解决方案是使用内联子查询:

代码语言:javascript
复制
select 
    t.*,
    (
        select sum(t1.qty) 
        from mytable t1 
        where 
            t1.article = t.article
            and t1.date between t.date - interval 28 days and t.date
    ) sum_qty_28_days
from mytable t
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59249373

复制
相关文章

相似问题

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