mysql 分组查询 第二条_mysql在group by分组后查询第二条/第三条乃至每组中任意一条数据...

昨天老板让我查询项目中(众筹),没人刚发起感召后,前三笔钱的入账时间和金额,这把大哥整懵逼了,group by在某些方面是好使,但这次不能为我所用了,获取第一笔进账是简单,可以用group by 直接获取就好,但是后面的呐,我百度反思后,最终实现,上代码,今天写篇博客,也算是记录一下这个知识点:

获取第一笔进账,我是这么搞得

select o.id,f.createdTime,round(f.money/100,0),sum(f.money) ct from(select *from organise where periodId = 251 and status = 4)o,follower f where f.status=1 and f.organiseId = o.id group by o.id order by o.id desc

organise 为发起表    follower为支持明细表

第一笔,通过对感召人进行分组  group by  o.id 排序后获取的就是第一比的进账时间/金额

想要获取第二笔进账,group by 就无能为力了,需要用上limit 1,1 ,代码如下:

SELECT aa.* FROM follower aa WHERE aa.id=(SELECT f.id from(SELECT id FROM organise WHERE periodId=251 and status=4)o,follower f WHERE o.id = f.organiseId and f.status=1

and aa.organiseId =o.id ORDER BY f.createdTime LIMIT 1,1) ORDER BY aa.organiseId desc

思路: 先根据感召者的发起id关联支持表,limit查出查出需要的是第几条数据,然后再利用最外面的支持表进行反查,最后获取自己想要的数据

话说这样的sql语句,是不能应用在项目中的,因为会花大量的时间,查询这条数据得至少一份钟的时间.请慎用,在项目中还是建议用代码的形式去实现,仅仅想直接用sql获取的这种方法,是耗时耗性能的不可取的!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值