昨天老板让我查询项目中(众筹),没人刚发起感召后,前三笔钱的入账时间和金额,这把大哥整懵逼了,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获取的这种方法,是耗时耗性能的不可取的!