使用表格:
id | name | job | rank
01 john teacher 4
02 mark teacher 2
03 phil plummer 1
04 dave teacher 7
05 jim plummer 9
06 bill plummer 2
如何选择每个作业最多2行(如果可能,按每个组中的排名ASC排序,以便选择每个组中最低的两个排名)。我要找的结果是:
02 mark teacher 2
01 john teacher 4
03 phil plummer 1
06 bill plummer 2
这基本上按作业分组,限制为2并按等级排序。我一直在尝试使用GROUP BY以及LEFT JOIN,但我无法弄清楚如何做到这一点。使用GROUPING BY作业创建作业的“临时列表”时,如何多次加入该作业?
答案 0 :(得分:4)
SELECT id, name, job, rank
FROM TableName a
WHERE
(
SELECT COUNT(*)
FROM TableName as f
WHERE f.job = a.job AND
f.rank <= a.rank
) <= 2;