分析函数
分析函数的使用
1.rank() over(partition by class order by order):对班级进行分组后,对分数进行排序
partition by用于给结果集分组
rank在每个分组内进行排名
rank()over()排序后,相同名次排序一样,但是下一位直接跳过,比如:1、2、2、4
2.dense_rank() over()
排序后,相同名次排序一样,下一位延续排序,比如:1、2、2、3
3.row_number() over()
排序后,相同名次排序不出现相同值,比如:1、2、3、4
与聚合函数一起使用
1、sum()over(order by ):对每一行和前面所有行进行求和运算
min()over(order by ):对每一行和前面所有行进行求最小值
max()over(order by ):对每一行和前面所有行进行求最大值
avg()over(order by ):对每一行和前面所有行进行求平均值
sum()over(order by rows 2 preceding):一行与前两行或者后两行进行运算
sum()over(order by rows between 2 preceding and 2 following):以这一行为中心的5行,也就是之前2行,之后2行进行求和运算(注意的是following不能单独使用)
sum()over(order by rows between current and 2 following):当前行和后两行就行求和运算