ホームページ >データベース >mysql チュートリアル >SQL RANK() と ROW_NUMBER(): 違いは何ですか?

SQL RANK() と ROW_NUMBER(): 違いは何ですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2025-01-13 16:52:44643ブラウズ

SQL RANK() vs. ROW_NUMBER(): What's the Difference?

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。