VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > 数据库 > T-SQL >
  • 认识一下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 如果加上这个参数,就会以哪个字段进行排序,并统计当前行跟记录之上的数据进行计算,如果没有,就是统计全部行
出处:https://www.cnblogs.com/caijt/p/17135937.html

相关教程