第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會有你想問的

獲取每組分組結(jié)果的前n條記錄

獲取每組分組結(jié)果的前n條記錄

翻閱古今 2019-05-25 16:46:40
獲取每組分組結(jié)果的前n條記錄以下是最簡單的示例,盡管任何解決方案都應(yīng)該能夠擴(kuò)展到需要的n個(gè)頂級結(jié)果:給出如下表格,包括人,組和年齡列,您如何獲得每組中最老的2個(gè)人?(組內(nèi)的關(guān)系不應(yīng)該產(chǎn)生更多結(jié)果,但按字母順序給出前2個(gè))+ -------- + ------- + ----- +| 人| 集團(tuán)| 年齡|+ -------- + ------- + ----- +| 鮑勃| 1 | 32 || 吉爾| 1 | 34 || 肖恩| 1 | 42 || 杰克| 2 | 29 || 保羅| 2 | 36 || 勞拉| 2 | 39 |+ -------- + ------- + ----- +期望的結(jié)果集:+ -------- + ------- + ----- +| 肖恩| 1 | 42 || 吉爾| 1 | 34 || 勞拉| 2 | 39 || 保羅| 2 | 36 |+ -------- + ------- + ----- +注意:此問題建立在前一個(gè)問題的基礎(chǔ)上 - 獲取每組分組SQL結(jié)果的最大值記錄 - 從每個(gè)組中獲取單個(gè)頂行,并從@Bohemian收到一個(gè)特定的MySQL特定答案:select * from (select * from mytable order by `Group`, Age desc, Person) xgroup by `Group`我希望能夠建立起來,但我不知道如何。
查看完整描述

4 回答

?
慕尼黑5688855

TA貢獻(xiàn)1848條經(jīng)驗(yàn) 獲得超2個(gè)贊

在其他數(shù)據(jù)庫中,您可以使用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發(fā)布了一個(gè)非常相似的答案:給他+1。然而,這個(gè)答案有兩個(gè)小優(yōu)點(diǎn):

  1. 這是一個(gè)單一的查詢。變量在SELECT語句中初始化。

  2. 它處理問題中描述的關(guān)系(按名稱的字母順序)。

所以我會留在這里,以防它可以幫助某人。


查看完整回答
反對 回復(fù) 2019-05-25
  • 4 回答
  • 0 關(guān)注
  • 609 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號