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

如何在SQL中选择每个组的前两行?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-31 15:13:13601浏览

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

选择每个 SQL 组中的前两行

在 SQL 中,常见任务是仅检索每个组的前几行。然而,用于分组的标准聚合函数(例如 MAX() 和 MIN())仅允许选择最高或最低值。

选择每个名称的前两个分数的查询:

为了应对这一挑战,需要更复杂的查询。以下是如何为所提供的表中的每个名称选择前两个分数的示例:

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

说明:

  • 外部查询 (SELECT * ...) 检索测试表中的所有行。
  • 子查询 (SELECT COUNT(*) ...) 确定有多少行测试表中每个名称都存在分数等于或大于当前行分数的记录。
  • 然后,WHERE 子句通过确保子查询的计数小于来过滤外部查询中的行或等于 2。

示例输出:

上面的查询返回以下输出:

NAME    SCORE
-----------------
willy       2
willy       3
zoe         5
zoe         6

此输出根据要求包括表中每个名称的前两个分数。

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

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