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

获取每组分组结果的前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`

我希望能够建立起来,但我不知道如何。


翻阅古今
浏览 586回答 4
4回答

慕尼黑5688855

在其他数据库中,您可以使用ROW_NUMBER。MySQL不支持,ROW_NUMBER但您可以使用变量来模拟它:SELECT &nbsp;&nbsp;&nbsp;&nbsp;person, &nbsp;&nbsp;&nbsp;&nbsp;groupname, &nbsp;&nbsp;&nbsp;&nbsp;ageFROM( &nbsp;&nbsp;&nbsp;&nbsp;SELECT &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;person, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;groupname, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;age, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;@rn&nbsp;:=&nbsp;IF(@prev&nbsp;=&nbsp;groupname,&nbsp;@rn&nbsp;+&nbsp;1,&nbsp;1)&nbsp;AS&nbsp;rn, &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;@prev&nbsp;:=&nbsp;groupname&nbsp;&nbsp;&nbsp;&nbsp;FROM&nbsp;mytable&nbsp;&nbsp;&nbsp;&nbsp;JOIN&nbsp;(SELECT&nbsp;@prev&nbsp;:=&nbsp;NULL,&nbsp;@rn&nbsp;:=&nbsp;0)&nbsp;AS&nbsp;vars&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;ORDER&nbsp;BY&nbsp;groupname,&nbsp;age&nbsp;DESC,&nbsp;person)&nbsp;AS&nbsp;T1WHERE&nbsp;rn&nbsp;<=&nbsp;2看到它在线工作:sqlfiddle编辑我刚注意到bluefeet发布了一个非常相似的答案:给他+1。然而,这个答案有两个小优点:这是一个单一的查询。变量在SELECT语句中初始化。它处理问题中描述的关系(按名称的字母顺序)。所以我会留在这里,以防它可以帮助某人。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

MySQL