分析函数排名 rank()、dense_rank()、row_number()

【语法】row_number() over( partition by col1 order by col2);

【功能】表示根据col1分组,在分组内部根据col2排序,而这个值就表示每组内部排序后的顺序编码(组内连续的 唯一的);

row_number():返回的是行信息,没有排名;

dense_rank():返回的相关等级不会跳跃;

rank():返回的返回的相关等级会跳跃;

分析函数排名 rank()、dense_rank()、row_number()

select employee_name,
       money,
       rank() over(order by money) rank,
       dense_rank() over(order by money) dense_rank,
       row_number() over(order by money) row_number
  from salary;

分析函数排名 rank()、dense_rank()、row_number()

 

 

 rank() over():查出指定条件后的进行排名。特点是,加入是对学生排名,使用这个函数,成绩相同的两名是并列,下一位同学空出所占的名次。

举例:select name,subject,score,rank() over(partition by subject order by score desc) rank from student_score;

分析函数排名 rank()、dense_rank()、row_number()

 

dense_rank() over():与ran() over的区别是,两名学生的成绩并列以后,下一位同学并不空出所占的名次。

举例:select name,subject,score,dense_rank() over(partition by subject order by score desc) rank from student_score;

分析函数排名 rank()、dense_rank()、row_number()

row_number() over():这个函数不需要考虑是否并列,哪怕根据条件查询出来的数值相同也会进行连续排名.

举例:select name,subject,score,row_number() over(partition by subject order by score desc) rank from student_score;

分析函数排名 rank()、dense_rank()、row_number()

注意:

使用rank() over的时候,空值是最大的,如果排序字段为null,可能造成null字段排在最前面,影响排序结果。

rank() over(partition by course order by score desc nulls last)来规避这个问题。

举例:select name,subject,score,rank() over(partition by subject order by score desc nulls last) rank from student_score;

分析函数排名 rank()、dense_rank()、row_number()

 

上一篇:[转]SQL Server 性能调优(内存)


下一篇:剑指offer 最长公共前缀Java