首頁 >資料庫 >mysql教程 >如何在SQL中選擇每個群組的前N行?

如何在SQL中選擇每個群組的前N行?

Barbara Streisand
Barbara Streisand原創
2024-12-31 08:42:10722瀏覽

How to Select the Top N Rows for Each Group in SQL?

SQL 中每個群組的前N 行

在SQL 中,可以使用視窗函數來完成為每個群組選擇前N 行。視窗函數允許對一組行(稱為視窗)執行計算,這些行由指定的排序和分區定義。在本例中,我們希望為每個群組選擇前兩行,這可以透過以下步驟來實現:

  1. 對資料進行分區: 定義您要針對的群組想要使用PARTITION BY 子句選擇頂部行。在此範例中,我們希望按 NAME 列對資料進行分組。
  2. 對每個群組中的行進行排名: 使用 ROW_NUMBER() 視窗函數為每個群組中的每一行分配一個序號每個群組,從 1 開始。這將為我們提供該組中每一行的排名。
  3. 過濾頂部rows: 應用過濾器僅選擇排名為 1 或 2 的行。這將為我們提供每組的前兩行。

以下是實現這些的範例查詢步驟:

SELECT *
FROM (
    SELECT *, RANK() OVER (PARTITION BY NAME ORDER BY SCORE DESC) AS row_rank
    FROM test
) AS ranked
WHERE row_rank <= 2

此查詢將產生所需的輸出,如下所示:

NAME    SCORE
-----------------
willy       2
willy       3
zoe         5
zoe         6

以上是如何在SQL中選擇每個群組的前N行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn