sql 中 rank() over() 函数用于为数据记录分配排名值。它接受一个 order by 子句,指定排名依据的列和排序顺序。参数包括:列名(参与排名的列)、排序顺序(升序或降序)以及 null 值的处理方式(首位、末尾或仅非 null 值)。该函数用于对值相同的记录分配相同的排名或唯一排名,并可以排除或处理 null 值。
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 值进行排名。
以上就是sql中rank(over(的使用方法的详细内容.