mysql取每个分类前5个

需要取每天前5的数据,然后各种百度,由于只有oracle有rank() over (partition by,所以mysql就特别麻烦,找到了2种方法

 

方法一:

select * from cqyd b where b.时间 between '2019-12-08' and '2019-12-09' 
and  3>(select count(1) from cqydc where b.时间=c.时间 and c.请求频次>b.请求频次)

 

方法二:

SELECT
    *
FROM
    cqyd AS a
LEFT JOIN cqyd AS b ON a.时间 = b.时间
AND a.请求频次 < b.请求频次
WHERE
    1=1
GROUP BY
    a.时间,
    a.请求频次
HAVING
    count(1) < 5
ORDER BY
    a.时间 ASC,
    a.请求频次 DESC;

 

 

比较:

方法一在百度上面特别多,且效率特别低,只查询两天的数据,且没有索引,共3600条数据,执行了600秒,而方法二执行了不到200秒。

做个记录!

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值