2019-10-24【MySQL】查詢每組得分最高的前n名

查找每個(gè)部門得分最高的2位員工

# 方法一
SELECT a.* 
FROM test AS a
  LEFT JOIN test AS a2 
  ON a.department = a2.department AND a.score <= a2.score
GROUP BY a.name
HAVING COUNT(*) <= 2;

# 方法二
SELECT test.name, test.department, test.score
FROM test
WHERE(SELECT COUNT(*) FROM test as test2
      WHERE test2.department = test.department AND test2.score >= test.score
     ) <= 2


原始數(shù)據(jù)
# name, department, score
'joe', 'ops', '111'
'aaa', 'ops', '222'
'bbb', 'ops', '333'
'ccc', 'ops', '555'
'ddd', 'dev', '999'
'eee', 'dev', '888'
'fff', 'dev', '777'
'ggg', 'dev', '666'

期望結(jié)果:
# name, department, score
'bbb', 'ops', '333'
'ccc', 'ops', '555'
'ddd', 'dev', '999'
'eee', 'dev', '888'

參考鏈接

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • pyspark.sql模塊 模塊上下文 Spark SQL和DataFrames的重要類: pyspark.sql...
    mpro閱讀 9,920評(píng)論 0 13
  • http://spark.apache.org/docs/latest/api/python/index.html...
    mpro閱讀 6,284評(píng)論 0 4
  • 這么多年來(lái) 我都沒(méi)有意識(shí)到今天的日子與往常有何不同。今天好像意識(shí)到了。是一個(gè)甜甜的日子。不過(guò) 我是苦苦的。巨苦。 ...
    福進(jìn)進(jìn)閱讀 279評(píng)論 0 0
  • 迷鹿mirror閱讀 262評(píng)論 0 0
  • “生而為人,很抱歉?!? 出自日本電影《被嫌棄的松子的一生》,導(dǎo)演中島哲也為主人公川尻松子給世界留下的最后一...
    MsKouKou閱讀 733評(píng)論 2 7

友情鏈接更多精彩內(nèi)容