今天,一个同学的问我一条问题,具体如下:
为了测试,我建立了一个表,叫student,并添加了N条数据:
最终预期结果应该是:
根据题意是,按class分组,然后取id靠前的两名,相信大多数人都能想到基本组合:
SELECT a.*
FROM student a
ORDER BY a.class, a.id;
另加:Limit 0,2来配合。
(注:MYSQL 中没有top n的写法,取代的是LIMIT。)
Limit 0,n只能取到最前的n位,但如何能取到每个班的前两位呢,就无从下手了。
下面我来具体分析一下这题的解法:
1、获取每个class的前两位:
SELECT a.*
FROM student a
WHERE
(
SELECT COUNT(*)
FROM student
WHERE class = a.class
AND id < a.id
) < 2
#遍历所有记录,然后取该条记录与同班中的所有记录比较,只有当班上不超过两个人(含两个人)比该记录id小的话,该记录才被认定为该记录id排名前2,然后显示出来。
2、当获取所有合格的数据有,按class与id排序:
在最后添加:
ORDER BY a.class, a.id;
最终结果:
SELECT a. *
FROM student a
WHERE (
SELECT COUNT( * )
FROM student
WHERE class = a.class
AND id < a.id
) <2
ORDER BY a.class, a.id
LIMIT 0 , 30;