首页 >数据库 >mysql教程 >如何在 SQL 中获取每个组的前两行?

如何在 SQL 中获取每个组的前两行?

Patricia Arquette
Patricia Arquette原创
2024-12-29 11:05:11624浏览

How to Get the Top Two Rows for Each Group in SQL?

在 SQL 中获取每个组的前两行

SQL 查询使用户能够从表中提取特定数据,但是如果您需要怎么办选择每组的前两行?当您想要分析得分最高的记录或检索组内的多个值时,可能会遇到这种情况。

让我们以下表为例:

NAME SCORE
willy 1
willy 2
willy 3
zoe 4
zoe 5
zoe 6

要检索每个名字的最高两个分数,我们可以使用以下 SQL 查询:

SELECT *
FROM test s
WHERE
    (
        SELECT COUNT(*)
        FROM test f
        WHERE f.name = s.name AND
              f.score >= s.score
    ) <= 2

以下是查询的方式工作原理:

  • 外部查询(SELECT * FROM test)从测试表中选择所有行。
  • 括在括号中的内部查询计算表中的行数给定名称和分数大于或等于当前行分数的测试表 (f.score >= s.score)。
  • 外部查询的 WHERE 子句根据内部查询的计数过滤行。仅选择计数小于或等于 2 的行。这确保我们获得每组的前两名分数。

此查询的预期输出如下:

NAME SCORE
willy 2
willy 3
zoe 5
zoe 6

以上是如何在 SQL 中获取每个组的前两行?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn