mysql 分组查询最近时间的数据

工作需求:查询每个手机号的最近时间的信息记录,数据库mysql

抽象一下就是按某字段分组,每组倒序或正序,只取一条记录

表结构大致如下

表名:Mob

id(自增) mobile createtime
1 123 2018-10-25 13:13:25
2 123 2018-10-23 00:00:00
3 223 2019-01-01 23:59:59

最开始的思路就是先对表中的数据进行一次按时间排序,接着再对手机号进行group by,会默认取第一行,这不就是最近时间的数据了吗?

然后就开始愉快的写

SELECT * FROM (SELECT * FROM Mob ORDER BY createtime DESC) t GROUP BY mobile ORDER BY createtime DESC

结果无效。。。问题就出在,别人的mysql的group by都很聪明的取第一条,我的mysql 就跟 傻 X一样,我行我素,这个方法对我来讲失败了,可能别人会有效果吧。 不过子查询效率不高,容易形成慢sql,有待商榷

最后用内连接做了出来,主要依靠的还是表中的自增字段:id,真是功臣!

SELECT m1.id, m1.mobile, m1.createtime
FROM Mob m1 LEFT JOIN Mob m2
    ON (m1.mobile = m2.mobile AND m1.id < m2.id)
WHERE m2.id IS NULL
ORDER BY createtime DESC

至此问题解决了,效率也要比子查询快一些

如果大佬有更好的方法,欢迎留言教教我,谢谢!

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 转 # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    吕品㗊阅读 10,134评论 0 44
  • 今天看到一位朋友写的mysql笔记总结,觉得写的很详细很用心,这里转载一下,供大家参考下,也希望大家能关注他原文地...
    信仰与初衷阅读 4,834评论 0 30
  • 一、MySQL优化 MySQL优化从哪些方面入手: (1)存储层(数据) 构建良好的数据结构。可以大大的提升我们S...
    宠辱不惊丶岁月静好阅读 2,654评论 1 8
  • 前面的章节我们介绍了如何设计最优的库表结构、 如何建立最好的索引, 这些对于高性能来说是必不可少的。 但这些还不够...
    好好学习Sun阅读 2,774评论 0 38
  • 我人细鬼大,在读小学时就开始偷偷看些关于爱情的书籍。书中缠绵曲折、轰轰烈烈又至死不渝的爱情,同为男主人公英俊潇洒、...
    七星高照阅读 277评论 0 0

友情链接更多精彩内容