为了账号安全,请及时绑定邮箱和手机立即绑定

获取每组分组结果的前n条记录

获取每组分组结果的前n条记录

翻阅古今 2019-05-25 16:46:40
获取每组分组结果的前n条记录以下是最简单的示例,尽管任何解决方案都应该能够扩展到需要的n个顶级结果:给出如下表格,包括人,组和年龄列,您如何获得每组中最老的2个人?(组内的关系不应该产生更多结果,但按字母顺序给出前2个)+ -------- + ------- + ----- +| 人| 集团| 年龄|+ -------- + ------- + ----- +| 鲍勃| 1 | 32 || 吉尔| 1 | 34 || 肖恩| 1 | 42 || 杰克| 2 | 29 || 保罗| 2 | 36 || 劳拉| 2 | 39 |+ -------- + ------- + ----- +期望的结果集:+ -------- + ------- + ----- +| 肖恩| 1 | 42 || 吉尔| 1 | 34 || 劳拉| 2 | 39 || 保罗| 2 | 36 |+ -------- + ------- + ----- +注意:此问题建立在前一个问题的基础上 - 获取每组分组SQL结果的最大值记录 - 从每个组中获取单个顶行,并从@Bohemian收到一个特定的MySQL特定答案:select * from (select * from mytable order by `Group`, Age desc, Person) xgroup by `Group`我希望能够建立起来,但我不知道如何。
查看完整描述

4 回答

?
慕尼黑5688855

TA贡献1848条经验 获得超2个赞

在其他数据库中,您可以使用ROW_NUMBER。MySQL不支持,ROW_NUMBER但您可以使用变量来模拟它:

SELECT
    person,
    groupname,
    ageFROM(
    SELECT
        person,
        groupname,
        age,
        @rn := IF(@prev = groupname, @rn + 1, 1) AS rn,
        @prev := groupname    FROM mytable    JOIN (SELECT @prev := NULL, @rn := 0) AS vars    
        ORDER BY groupname, age DESC, person) AS T1WHERE rn <= 2

看到它在线工作:sqlfiddle


编辑我刚注意到bluefeet发布了一个非常相似的答案:给他+1。然而,这个答案有两个小优点:

  1. 这是一个单一的查询。变量在SELECT语句中初始化。

  2. 它处理问题中描述的关系(按名称的字母顺序)。

所以我会留在这里,以防它可以帮助某人。


查看完整回答
反对 回复 2019-05-25
  • 4 回答
  • 0 关注
  • 585 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信