朋友出了个题,各有A,B,C三人做游戏,记录第次得分,经几十次游戏后,成绩如下:
ID Name Score
1 a 88
2 b 76
3 c 66
4 c 90
5 b 77
6 a 56
7 b 77
8 c 67
9 a 44
......
当然还有很多

要求搜索A,B,C三人各最好成绩,并且要列出最好成绩的序号即ID号
如:
ID Name Score
1 a 88
5 b 77
4 c 90




SELECT MAX(Score), [Name] GROUP BY [Name]
但这该死的 ID 号怎么也插入不了

SELECT [ID],[Name],Score
FROM Table1 a
WHERE Score IN
(SELECT MAX(b.Score) AS MAXScore
FROM Table1 b
GROUP BY b.[Name] )
可是,这 ID 号还是多出来了,原因是由于该搜索是以最大值的集合作依据,如77这个最大值,可能是B的最大值,但是A和C可能也会出现77这个数,但不是最大值,所以......

SELECT [ID],[Name],Score
FROM Table1 a
WHERE Score IN
(SELECT MAX(b.Score) AS MAXScore
FROM Table1 b
GROUP BY b.[Name] HAVING a.[Name]=b.[Name] )
结果顺利出来结果
