在SQL中,如何为每个组选择前2行
我有一个表格如下:
NAME SCORE
-----------------
willy 1
willy 2
willy 3
zoe 4
zoe 5
zoe 6
这是示例
group by 的聚合函数只允许我得到每个name 的最高分.我想查询每个 name 的最高 2 分,我该怎么做?
The aggregation function for group by only allow me to get the highest score for each name.
I would like to make a query to get the highest 2 score for each name, how should I do?
我的预期输出是
NAME SCORE
-----------------
willy 2
willy 3
zoe 5
zoe 6
推荐答案
SELECT *
FROM test s
WHERE
(
SELECT COUNT(*)
FROM test f
WHERE f.name = s.name AND
f.score >= s.score
) <= 2
- SQLFiddle 演示
相关文章