您好,欢迎访问一九零五行业门户网

MySQL中rank() over、dense_rank() over和row_number() over怎么用

上述的这道题,如果不使用本次用到的函数的答案如下,也就是说,如果你的mysql无法使用本篇中的函数,可以通过下面的语法逻辑做替换。
select t1.score as score, ( select count(distinct t2.score) from scores t2 where t2.score >= t1.score ) as `rank` from scores t1 order by t1.score desc
rank() over(业务逻辑)作用:查出指定条件后的进行排名,条件相同排名相同,排名间断不连续。
这个函数可用于学生排名,其中成绩相同的两个学生会被并列,下一名学生将腾出其应有的名次。即:1 1 3 4 5 5 7
select id, name, score, rank() over(order by score desc) as 'rank' from student
dense_rank() over(业务逻辑)作用:查出指定条件后的进行排名,条件相同排名相同,排名间断不连续。
说明:和rank() over 的作用相同,区别在于dense_rank() over 排名是密集连续的。使用此函数来确定学生的排名。当出现成绩相同的情况时,两名学生将并列该排名,排名的下一位将根据接下来的名次进行确定。即:1 1 2 3 4 5 5 6
select id, name, score, dense_rank() over(order by score desc) as 'rank' from student
row_number() over(业务逻辑)作用:查出指定条件后的进行排名,条件相同排名也不相同,排名间断不连续。
即使查询出的数值相同,这个函数会进行连续排序,不需要考虑是否并列。即:1 2 3 4 5 6
select id, name, score, row_number() over(order by score desc) as 'rank' from student
后记函数中的业务逻辑可以是复杂的,不局限于 order by,也可以加 partition by。
### 分班级排名select id, name, score, class, row_number() over(partition by class order by score desc) as 'rank' from student
以上就是mysql中rank() over、dense_rank() over和row_number() over怎么用的详细内容。
其它类似信息

推荐信息