分组后查找每组的前N条记录

今天,一个同学的问我一条问题,具体如下:

 

 

为了测试,我建立了一个表,叫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;

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值