首頁 > 資料庫 > mysql教程 > MySQL分組前如何對結果進行排序?

MySQL分組前如何對結果進行排序?

Linda Hamilton
發布: 2024-11-11 18:04:03
原創
929 人瀏覽過

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
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板