ホームページ >データベース >mysql チュートリアル >SQL RANK() と ROW_NUMBER(): 違いは何ですか?
SQL RANK() と ROW_NUMBER() の違い
SQL ランキング関数を使用する場合、RANK() と ROW_NUMBER() の違いを理解することが重要です。場合によっては似ているように見えても、重複した値を処理する場合には動作が異なる場合があります。
ROW_NUMBER() と RANK() の比較
ROW_NUMBER() は、並べ替え列の値が同じかどうかに関係なく、連続する整数値を各行に割り当てます。これは、ROW_NUMBER() が常に各行に一意の整数を割り当てることを意味します。
一方、RANK() は、パーティション内での行のソート順に基づいて各行にランクを割り当てます。同じ並べ替え値を持つ行には同じランクが与えられます。同点の場合、順位に差が生じます。
デモ
次の SQL クエリは、ROW_NUMBER() と RANK() の違いを示しています。
<code class="language-sql">SELECT ID, [Description], RANK() OVER(PARTITION BY StyleID ORDER BY ID) as 'Rank' FROM SubStyle</code>
<code class="language-sql">SELECT ID, [Description], ROW_NUMBER() OVER(PARTITION BY StyleID ORDER BY ID) as 'RowNumber' FROM SubStyle</code>
これらのクエリを使用すると、最初は両方の結果セットが同一に見えます。ただし、順位が同点の場合はその差が顕著になります。次のデータ例を考えてみましょう:
<code class="language-sql">WITH T(StyleID, ID) AS (SELECT 1,1 UNION ALL SELECT 1,1 UNION ALL SELECT 1,1 UNION ALL SELECT 1,2) SELECT *, RANK() OVER(PARTITION BY StyleID ORDER BY ID) AS [RANK], ROW_NUMBER() OVER(PARTITION BY StyleID ORDER BY ID) AS [ROW_NUMBER], DENSE_RANK() OVER(PARTITION BY StyleID ORDER BY ID) AS [DENSE_RANK] FROM T</code>
結果:
<code>StyleID ID RANK ROW_NUMBER DENSE_RANK ----------- -------- --------- --------------- ---------- 1 1 1 1 1 1 1 1 2 1 1 1 1 3 1 1 2 4 4 2</code>
この例では、ROW_NUMBER() は同点であってもインクリメントしますが、RANK() は同点のすべての行に同じランクを割り当てます。 DENSE_RANK() は RANK() に似ていますが、次の異なるランク (2) を次の異なるランキング値に割り当てます。
以上がSQL RANK() と ROW_NUMBER(): 違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。