认识一下SQL的窗口函数

打印 上一主题 下一主题

主题 1022|帖子 1022|积分 3066

最近在弄一个报表,要求每行的最后一列字段显示余额金额,就是上一行余额金额加上当前行的余额
一开始我都是在程序里面处理,这次需要用Sql写出来,一下犯难了。
 
同事介绍到有个窗口函数可以实现,我用了好多年的SqlServer,都不知有这个东西。
记录一下,免得以后忘记了

 以这个表为例子
  1. --不分组统计
  2. select *,
  3.     sum(score) over(order by score desc,id)  as '分数余额',
  4.     sum(score) over() as '分数总计',
  5.     rank() over(order by score desc ) '排名',
  6.         dense_rank() over(order by score desc) as '排名2',
  7.         row_number() over(order by score desc) as '行号'
  8.     from Test01 order by score desc
  9. --分组统计
  10. select *,   
  11.     sum(score) over(partition by class order by score desc,id) as '所在班级分数余额',
  12.     sum(score) over(partition by class) as '所在班级分数总计',
  13.     rank() over(partition by class order by score desc ) '所在班级排名',
  14.         dense_rank() over(partition by class order by score desc) as '所在班级排名2',
  15.         row_number() over(partition by class order by score desc) as '所在班级行号'
  16.     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 如果加上这个参数,就会以哪个字段进行排序,并统计当前行跟记录之上的数据进行计算,如果没有,就是统计全部行 

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

羊蹓狼

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表