首页 > 数据库 > mysql教程 > MySQL分组前如何对结果进行排序?

MySQL分组前如何对结果进行排序?

Linda Hamilton
发布: 2024-11-11 18:04:03
原创
936 人浏览过

How to Order Results Before Grouping in MySQL?

MySQL 在 Group By 之前排序

在 MySQL 中,执行 GROUP BY 子句通常会在分组形成后对结果进行排序。但是,在某些情况下,您希望在分组之前对结果进行排序。

考虑以下查询:

SELECT wp_posts.*
FROM wp_posts
WHERE wp_posts.post_status='publish'
AND wp_posts.post_type='post'
GROUP BY wp_posts.post_author
ORDER BY wp_posts.post_date DESC
登录后复制

此查询旨在查找每个作者的最新帖子,然后将其分组结果。但是,问题是它是在分组之后对结果进行排序,而不是之前。

解决方案

要在分组之前对结果进行排序,可以使用以下方法:

SELECT wp_posts.*
FROM wp_posts
WHERE wp_posts.post_status='publish'
AND wp_posts.post_type='post'
GROUP BY wp_posts.post_author
HAVING wp_posts.post_date = MAX(wp_posts.post_date)
ORDER BY wp_posts.post_date DESC
登录后复制

HAVING 子句确保在分组之前仅选择每个作者的最新帖子。

替代解决方案

如果 HAVING子句不可行,例如在 Postgres 或 SQL Server 中,您可以使用以下替代解决方案:

SELECT
    wp_posts.*
FROM
    wp_posts
JOIN
    (
        SELECT
            g.post_author,
            MAX(g.post_date) AS post_date
        FROM wp_posts AS g
        WHERE
            g.post_status='publish'
            AND g.post_type='post'
        GROUP BY g.post_author
    ) AS t
    ON wp_posts.post_author = t.post_author AND wp_posts.post_date = t.post_date
ORDER BY wp_posts.post_date
登录后复制

此查询使用子查询查找每个作者的最大发布日期,然后将其与原始表来检索实际的帖子记录。

以上是MySQL分组前如何对结果进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

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