窗口函数语法:
<窗口函数> over (partition by <用于分组的列名>
order by <用于排序的列名>
rows/range子句<用于定义窗口大小> )
<窗口函数>可以放以下两种函数:
1) 专用窗口函数,包括后面要讲到的rank, dense_rank, row_number等专用窗口函数。
2) 聚合函数,如sum. avg, count, max, min等
rank, dense_rank, row_number这三个函数的区别在这篇文章里有详细介绍,简略说就是:
分数 | Rank | Dense_Rank | Row_number |
---|---|---|---|
100 | 1 | 1 | 1 |
100 | 1 | 1 | 2 |
90 | 3 | 2 | 3 |
这里以sum()
为例子,使用常用的部门员工数据集,介绍聚合函数的不同组合用法
[ BETWEEN AND ]
rows n perceding
表示从当前行到前n行(一共n+1行)边界可取值(Start expr & End expr) | 说明 |
---|---|
Current Row | 当前行 |
N preceding | 前 n 行,n 为数字, 比如 2 Preceding 表示前2行 |
unbounded preceding | 开头 |
N following | 后N行,n 为数字, 比如 2 following 表示后2行 |
unbounded following | 结尾 |
range取特定日期区间 | 说明 |
---|---|
range interval 7-1 day preceding | 最近7天的值 |
range between interval 1 day preceding and interval 1 day following | 前后一天和当天的值 |
注:如果将这里的rows 换成range 结果是一样的,因为这里使用id号排序,id和行号一致。
Range 是根据值来组合排序的,结果中的第一行 Same的工资是60000, 而薪资范围内在50000-70000的人一共有4个,薪资范围内在55000-65000的人只有一个。
累计问题: 牛客网 SQL159 每个创作者每月的涨粉率及截止当前的总粉丝量
限制条件下的累计问题: 牛客网SQL160 国庆期间每类视频点赞量和转发量
The RANGE Clause in SQL Window Functions: 5 Practical Examples