Mysql group by top N

Mysql group by top N的问题(转)
 
   在日常工作中,经常要查询分组的前几名.oracle中可以通过row_num来支持查询, mysql暂时不支持row_num.那么如何来完成这个需求呢?
 
   例如:
 
表中的数据:
 
?
1
2
3
4
5
6
7
8
9
10
+ --------+-------+-----+
| Person | Group | Age |
+ --------+-------+-----+
| Bob    | 1     | 32  |
| Jill   | 1     | 34  |
| Shawn  | 1     | 42  |
| Jake   | 2     | 29  |
| Paul   | 2     | 36  |
| Laura  | 2     | 39  |
+ --------+-------+-----+

 

期望的结果:
 
?
1
2
3
4
5
6
+ --------+-------+-----+
| Shawn  | 1     | 42  |
| Jill   | 1     | 34  |
| Laura  | 2     | 39  |
| Paul   | 2     | 36  |
+ --------+-------+-----+

 

 
   方式一:借鉴oracle中row_num的思想,在sql中增加伪列.
?
1
2
3
4
5
6
7
8
9
10
11
12
set @num := 0, @ group := '' ;
 
select person, ` group `, age
from
(
    select person, ` group `, age,
       @num := if(@ group = ` group `, @num + 1, 1) as row_number,
       @ group := ` group ` as dummy
   from mytable
   order by ` Group `, Age desc , person
) as x
where x.row_number <= 2;

 

方式二:利用关联子查询
?
1
2
3
4
SELECT a.person, a. group , a.age FROM person AS a WHERE
( SELECT COUNT (*) FROM person AS b
WHERE b. group = a. group AND b.age >= a.age) <= 2
ORDER BY a. group ASC , a.age DESC
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值