首页 > 数据库 > mysql教程 > 如何高效地检索 MySQL 中每组的最后一行?

如何高效地检索 MySQL 中每组的最后一行?

Mary-Kate Olsen
发布: 2024-11-12 15:19:01
原创
298 人浏览过

How to Efficiently Retrieve the Last Row per Group in MySQL?

使用 MySQL 检索每组的“最后”行

问题:

找到一种更有效的方法来检索MySQL 表中每个组的最后一行,使用类似于以下的查询:

select * 
    from foo as a
    where a.id = (select max(id) from foo where uid = a.uid group by uid)
    group by uid;
登录后复制

潜在解决方案:

考虑此替代查询:

SELECT t1.* FROM foo t1
  LEFT JOIN foo t2
    ON t1.id < t2.id AND t1.uid = t2.uid
WHERE t2.id is NULL;
登录后复制

说明:

此查询 Left 根据 ID 列将表中的每一行与其后继行连接起来。如果不存在后继(即,它是组中的最后一行),则 t2.id 列将为 NULL。通过过滤 NULL,我们有效地隔离了每组的最后一行。

附加说明:

使用 EXPLAIN 分析原始查询和替代查询的查询性能解决方案。

此方法对于大型数据集和复杂分组特别有用。对于更简单的情况,其他方法可能更有效。

以上是如何高效地检索 MySQL 中每组的最后一行?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板