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中文網其他相關文章!