首頁 >資料庫 >mysql教程 >SQL RANK() 與 ROW_NUMBER():它們在處理關係時有何不同?

SQL RANK() 與 ROW_NUMBER():它們在處理關係時有何不同?

Susan Sarandon
Susan Sarandon原創
2025-01-13 16:56:43939瀏覽

SQL RANK() vs. ROW_NUMBER(): How Do They Differ When Handling Ties?

SQL RANK() 與 ROW_NUMBER(): 差異詳解

在 SQL 中,RANK() 和 ROW_NUMBER() 功能相似,容易混淆。然而,理解它們細微的差別對於有效的資料操作至關重要。

RANK() 與 ROW_NUMBER() 的比較

RANK() 為分區內具有相同排序值的行列分配相同的排名,而 ROW_NUMBER() 始終遞增,即使對於具有相同值的行列也是如此。

關鍵差異:處理重複值

RANK() 和 ROW_NUMBER() 之間的主要區別在於它們在遇到分區內重複值時的行為:

  • RANK(): 為重複值的行分配相同的排名。
  • ROW_NUMBER(): 重複值的行任意分配遞增的排名。

範例

考慮以下表格:

StyleID ID Description
1 1 Item A
1 1 Item B
1 1 Item C
1 2 Item D

使用以下查詢:

<code class="language-sql">SELECT ID, Description, RANK() OVER (PARTITION BY StyleID ORDER BY ID) AS 'Rank' FROM SubStyle;
SELECT ID, Description, ROW_NUMBER() OVER (PARTITION BY StyleID ORDER BY ID) AS 'RowNumber' FROM SubStyle;</code>

只有在分區內沒有重複值時,才能得到相同的結果。例如,如果您新增另一行,其中 StyleID 為 3,ID 為 1,您將觀察到以下結果:

StyleID ID Description Rank RowNumber
1 1 Item A 1 1
1 1 Item B 1 2
1 1 Item C 1 3
1 2 Item D 4 4
3 1 New Item 1 5

如您所見,對於 StyleID 為 3 的唯一值,ROW_NUMBER() 分配遞增的數字,而 RANK() 為其分配與 StyleID 為 1 的重複值行相同的排名。

結論

RANK() 和 ROW_NUMBER() 服務於不同的目的。 RANK() 用於對組內的唯一值進行排名,並適當地處理重複值。另一方面,ROW_NUMBER() 總是遞增,確保每一行都有一個不同的數值,即使對於重複值的行也是如此。在使用 SQL 資料時,理解這些差異對於做出明智的決策至關重要。

以上是SQL RANK() 與 ROW_NUMBER():它們在處理關係時有何不同?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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