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