SQL RANK() 與 ROW_NUMBER(): 差異詳解
在 SQL 中,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中文網其他相關文章!