使用Filter函数改善窗口函数中的条件聚合

FILTER子句常用于窗口函数计算中排除不符合特定条件的行。

其语法如下:

FUNC(...) FILTER(WHERE condition);

其中,FUNC是聚合函数或窗口函数的名称,如SUM、COUNT、AVG等。FILTER子句中的WHERE子句定义一个条件(condition),只有满足该条件的行才会被包含在窗口函数的计算中。

在工作中,我们常使用CASE WHEN表达式进行条件过滤,比如:

SELECT id
       ,SUM(CASE WHEN status = 'A' THEN amount ELSE 0 END) AS sum_a
       ,SUM(CASE WHEN status = 'B' THEN amount ELSE 0 END) AS sum_b
FROM table_a
GROUP BY id
;

对此,FILTER提供一种更加简洁的方式来处理窗口函数中的条件过滤。

SELECT id
       ,SUM(amount) FILTER(WHERE status = 'A') AS sum_a
       ,SUM(amount) FILTER(WHERE status = 'B') AS sum_b
FROM table_a
GROUP BY id
;

两者相比,FILTER让代码更加简洁且可读,避免CASE WHEN中冗长的条件分支,减少代码复杂度。

因此,在处理窗口函数中的条件聚合时,使用 FILTER 子句是一种不错的选择。

  • 7
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值