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

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

Linda Hamilton
Linda Hamilton原创
2024-11-11 18:04:03866浏览

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn