mysql—排序函数rank() over()、dense_rank() over()、row_num() over()


1.rank() over()

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

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

 

 

2.dense_rank() over()

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

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

 

 

3.row_num() over()

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

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

 

 

 

 

参考:https://www.cnblogs.com/scwbky/p/9558203.html


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM