登录
首页 >  数据库 >  MySQL

编写一个 SQL 查询来实现分数排名。

来源:SegmentFault

时间:2023-01-24 11:30:40 191浏览 收藏

在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是数据库学习者,那么本文《编写一个 SQL 查询来实现分数排名。》就很适合你!本篇内容主要包括编写一个 SQL 查询来实现分数排名。,希望对大家的知识积累有所帮助,助力实战开发!

编写一个 SQL 查询来实现分数排名。如果两个分数相同,则两个分数排名(Rank)相同。请注意,平分后的下一个名次应该是下一个连续的整数值。换句话说,名次之间不应该有“间隔”。

+----+-------+
| Id | Score |
+----+-------+
| 1  | 3.50  |
| 2  | 3.65  |
| 3  | 4.00  |
| 4  | 3.85  |
| 5  | 4.00  |
| 6  | 3.65  |
+----+-------+

例如,根据上述给定的 Scores 表,你的查询应该返回(按分数从高到低排列):

+-------+------+
| Score | Rank |
+-------+------+
| 4.00  | 1    |
| 4.00  | 1    |
| 3.85  | 2    |
| 3.65  | 3    |
| 3.65  | 3    |
| 3.50  | 4    |
+-------+------+

sql:

SELECT
    Score,
    (
        SELECT
            count(DISTINCT score)
        FROM
            Scores
        WHERE
            score >= s.score
    ) AS Rank
FROM
    Scores s
ORDER BY
    Score DESC;

到这里,我们也就讲完了《编写一个 SQL 查询来实现分数排名。》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于mysql的知识点!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>