MySQL Order By Before Group By:另一種方法
在MySQL 中,在分組之前對行進行排序可能具有挑戰性,特別是當所需的順序為不由後續的group by 保證。雖然使用子查詢是一種常見的解決方案,但它可能並不總是最佳方法。
在所呈現的場景中,目標是從 wp_posts 表中檢索每個作者的最新貼文。提供的查詢(包括被描述為「目前接受的答案」的查詢)無法一致地提供預期結果。
解決此問題而不訴諸子查詢的另一種解決方案是利用視窗函數的組合和自連接:
WITH LatestPostsPerAuthor AS ( SELECT *, ROW_NUMBER() OVER (PARTITION BY post_author ORDER BY post_date DESC) AS rn FROM wp_posts WHERE post_status='publish' AND post_type='post' ) SELECT a.* FROM LatestPostsPerAuthor a JOIN LatestPostsPerAuthor b ON a.rn = b.rn AND a.post_author = b.post_author GROUP BY a.post_author ORDER BY a.post_date DESC;
此查詢使用ROW_NUMBER() 視窗函數根據每個作者組中的post_date 為貼文分配排名。然後,自連線可確保僅保留排名最高的行(即最新的貼文)進行分組和排序。
透過使用這種方法,可以實現所需的結果,而無需額外的開銷子查詢,為給定場景提供準確且一致的結果。
以上是如何在不使用子查詢的情況下有效率地取得MySQL中每個作者的最新貼文?的詳細內容。更多資訊請關注PHP中文網其他相關文章!