0
点赞
收藏
分享

微信扫一扫

MySQL - 排序函数 Rank() Over()、Dense_rank() Over()、Row_number() Over()


Rank() Over()

rank() over(partition by subject order by score desc) rank

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

MySQL - 排序函数 Rank() Over()、Dense_rank() Over()、Row_number() Over()_MySQL

Dense_rank() Over()

dense_rank() over(partition by subject order by score desc) rank

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

 MySQL - 排序函数 Rank() Over()、Dense_rank() Over()、Row_number() Over()_数据库_02

Row_number() Over()

row_number() over(partition by subject order by score desc) rank

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

MySQL - 排序函数 Rank() Over()、Dense_rank() Over()、Row_number() Over()_ROW_NUMBER OVER_03

总结

  • ROW_NUMBER:1,2,3,4……
  • RANK:1,2,2,4……
  • DENSE_RANK:1,2,2,3……
  • 其实 DENSE 这个单词就暴露了它的特征:稠密的、紧凑的


举报

相关推荐

0 条评论