认识一下SQL的窗口函数
最近在弄一个报表,要求每行的最后一列字段显示余额金额,就是上一行余额金额加上当前行的余额
一开始我都是在程序里面处理,这次需要用Sql写出来,一下犯难了。
同事介绍到有个窗口函数可以实现,我用了好多年的SqlServer,都不知有这个东西。
记录一下,免得以后忘记了
以这个表为例子
--不分组统计 select *, sum(score) over(order by score desc,id) as '分数余额', sum(score) over() as '分数总计', rank() over(order by score desc ) '排名', dense_rank() over(order by score desc) as '排名2', row_number() over(order by score desc) as '行号' from Test01 order by score desc --分组统计 select *, sum(score) over(partition by class order by score desc,id) as '所在班级分数余额', sum(score) over(partition by class) as '所在班级分数总计', rank() over(partition by class order by score desc ) '所在班级排名', dense_rank() over(partition by class order by score desc) as '所在班级排名2', row_number() over(partition by class order by score desc) as '所在班级行号' from Test01 order by class, score desc
如果如下图所示
窗口函数大体可以分成两种
一种是聚合统计类型,partition by跟order by都是可选的,像sum、avg、count、max、min
一种是排行类型,必须有order by,partition by可选,像rank、dense_rank、row_number
Partition By 是以哪个字段进行分组,没有就是无分组,或者把全部数据当成一组
Order By 如果加上这个参数,就会以哪个字段进行排序,并统计当前行跟记录之上的数据进行计算,如果没有,就是统计全部行
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?