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

查找每个部门得分最高的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


原始数据
# 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'

期望结果:
# name, department, score
'bbb', 'ops', '333'
'ccc', 'ops', '555'
'ddd', 'dev', '999'
'eee', 'dev', '888'

参考链接

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • pyspark.sql模块 模块上下文 Spark SQL和DataFrames的重要类: pyspark.sql...
    mpro阅读 9,545评论 0 13
  • http://spark.apache.org/docs/latest/api/python/index.html...
    mpro阅读 6,153评论 0 4
  • 这么多年来 我都没有意识到今天的日子与往常有何不同。今天好像意识到了。是一个甜甜的日子。不过 我是苦苦的。巨苦。 ...
    福進進阅读 260评论 0 0
  • 迷鹿mirror阅读 247评论 0 0
  • “生而为人,很抱歉。” 出自日本电影《被嫌弃的松子的一生》,导演中岛哲也为主人公川尻松子给世界留下的最后一...
    MsKouKou阅读 665评论 2 7