sql中rank(over(的使用方法-SQL
SQL 中 RANK() OVER() 用法
RANK() OVER() 函数在 SQL 中用于对数据进行排名,并为每个记录分配一个排名值。该函数接受一个 ORDER BY 子句,指定排名依据的列和排序顺序。
语法:
RANK() OVER (ORDER BY 列名 [ASC|DESC] [NULLS FIRST|LAST|ONLY])
登录后复制
参数:
- 列名:指定参与排名的列。
- ASC|DESC:指定排名顺序(升序或降序)。
- NULLS FIRST|LAST|ONLY:指定 NULL 值的处理方式。
用法:
RANK() OVER() 函数用于对数据进行各种类型的排名,包括:
- 对值相同的记录分配相同的排名
- 对值不同的记录分配唯一排名
- 排除 NULL 值或将 NULL 值排在首位/末尾
示例:
以下示例根据 "分数" 列对 "学生" 表中的记录进行排名,从高到低:
SELECT *, RANK() OVER (ORDER BY 分数 DESC) AS 排名 FROM 学生;
登录后复制
结果如下:
学号 | 姓名 | 分数 | 排名 |
---|---|---|---|
1 | 小明 | 95 | 1 |
2 | 小华 | 90 | 2 |
3 | 小丽 | 85 | 3 |
4 | 小刚 | 80 | 4 |
注意事项:
- RANK() OVER() 返回的排名值从 1 开始,而不是 0。
- 如果排名依据的列中有多个记录具有相同的值,则这些记录将分配相同的排名值。
- 对于 NULL 值,NULLS FIRST 选项将 NULL 值排在首位,NULLS LAST 选项将 NULL 值排在末尾,NULLS ONLY 选项只对非 NULL 值进行排名。