有这样的一个表:

mysql实现成绩表中成绩的排名

如果两个分数相同,则两个分数排名(Rank)相同平分后的下一个名次应该是下一个连续的整数值。

因此,名次之间不应该有“间隔”!

此时有2种方法:

第一:

select grade, (select count(distinct grade) from class3 where grade>=s.grade) as Rank from class3 as s order by grade desc;

 

第二:

select grade,(select count(*) from (select distinct grade as s from class3) as new_scores where s >= grade) Rank from class3 order by grade desc;

 

相关文章:

  • 2021-07-10
  • 2021-04-22
  • 2022-12-23
  • 2021-11-23
  • 2021-12-14
  • 2021-08-10
  • 2022-01-10
猜你喜欢
  • 2022-01-11
  • 2022-02-23
  • 2021-12-17
  • 2021-11-19
  • 2022-12-23
  • 2022-12-23
  • 2021-04-27
相关资源
相似解决方案