C语言学习网

partition怎么实现分组聚合

发表于:2022-12-09 作者:安全数据网编辑
编辑最后更新 2022年12月09日,这篇文章主要讲解了"partition怎么实现分组聚合",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"partition怎么实现分组聚合"吧!selec

这篇文章主要讲解了"partition怎么实现分组聚合",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"partition怎么实现分组聚合"吧!

select * from (  select o.order_id,          o.user_id,          o.amount_money,          o.order_date,         o.update_date         row_number() over(partition by o.order_id, o.user_id order by o.update_date desc) RANK  from order o) tmp where tmp.RANK = 1

示例(业务库每日向数据仓库处理时, 未进行去重处理):

order_iduser_idamount_moneyorder_dateupdate_date
11202020-09-222020-09-23
11202020-09-222020-09-24
32402020-09-222020-09-23
42502020-09-222020-09-23

未过滤查询结果:

order_iduser_idamount_moneyorder_dateupdate_daterank
11202020-09-222020-09-232
11202020-09-222020-09-241
32402020-09-222020-09-231
42502020-09-222020-09-231

过滤后查询结果(where tmp.RANK = 1):

order_iduser_idamount_moneyorder_dateupdate_daterank
11202020-09-222020-09-241
32402020-09-222020-09-231
42502020-09-222020-09-231

备注:此分组聚合并不是很消耗时间, 几乎跟不加此开窗函数一样。

感谢各位的阅读,以上就是"partition怎么实现分组聚合"的内容了,经过本文的学习后,相信大家对partition怎么实现分组聚合这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

0