獲取每組分組結果的前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。然而,這個答案有兩個小優點:
這是一個單一的查詢。變量在SELECT語句中初始化。
它處理問題中描述的關系(按名稱的字母順序)。
所以我會留在這里,以防它可以幫助某人。
添加回答
舉報
0/150
提交
取消