mysql group top_Mysql group by top N的问题

在日常工作中,经常要查询分组的前几名.oracle中可以通过row_num来支持查询,mysql暂时不支持row_num.那么如何来完成这个需求呢?

例如:

表中的数据:

+--------+-------+-----+

| Person | Group | Age |

+--------+-------+-----+

| Bob | 1 | 32 |

| Jill | 1 | 34 |

| Shawn | 1 | 42 |

| Jake | 2 | 29 |

| Paul | 2 | 36 |

| Laura | 2 | 39 |

+--------+-------+-----+

期望的结果:

+--------+-------+-----+

| Shawn | 1 | 42 |

| Jill | 1 | 34 |

| Laura | 2 | 39 |

| Paul | 2 | 36 |

+--------+-------+-----+

方式一:借鉴oracle中row_num的思想,在sql中增加伪列.

set@num :=0,@group:='';select person,`group`, agefrom(select person,`group`, age,@num :=if(@group=`group`,@num +1,1)as row_number,@group:=`group`as dummy

frommytableorder by `Group`, Age desc, person

)asxwhere x.row_number <=2;

方式二:利用关联子查询

SELECTa.person,a.group,a.ageFROMpersonASaWHERE(SELECTCOUNT(*)FROMpersonASbWHEREb.group=a.groupANDb.age>=a.age)<=2ORDERBYa.groupASC,a.ageDESC

ps:

1.在我处理的实际问题而言,方式一的效率明显高于方式二.

参考链接:http://stackoverflow.com/questions/12113699/get-top-n-records-for-each-group-of-grouped-results.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值