mysql取出时间最近的⼀条字段_Mysql根据时间取出每组数据
中最新的⼀条
下策——查询出结果后将时间排序后取第⼀条
select * from a
where create_time<="2017-03-29 19:30:36"
order by create_time desc
limit 1
这样做虽然可以取出当前时间最近的⼀条记录,但是⼀次查询需要将表遍历⼀遍,对于百万以上数据查询将⽐较费时;limit是先取出全部结果,然后取第⼀条,相当于查询中占⽤了不必要的时间和空间;还有如果需要批量取出最近⼀条记录,⽐⽅说:“⼀个订单表,有⽤户,订单时间,⾦额,需要⼀次性查询所有⽤户的最近的⼀条订单记录”,那么每个⽤户⼀次查询就要做⼀次整表的遍历,数据⼤的情况下,时间将会以指数形式增长,不能投⼊实际使⽤。
中策——查询排序后group by
select * from (
mysql删除重复的数据保留一条select * from a
where create_time<="2017-03-29 19:30:36"
order by create_time desc
) group by user_id
后来发现使⽤group by 可以根据group by 的参数列分组,但返回的结果只有⼀条,仔细观察发现group by是将分组后的第⼀条记录返回。时间在查询后默认是顺序排列,因此需要先将时间倒序排列,⽅可取出距离当前最近⼀条。
这样查询实际上还是进⾏了两次查询,虽然时间上相⽐第⼀个⽅法有了质的飞跃,但是还可以进⼀步优化。
上策——将max() ⽅法和group by结合使⽤
select *,max(crea
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论