ホームページ >データベース >mysql チュートリアル >Oracle SQLで上位N位の最大値を取得するにはどうすればよいですか?

Oracle SQLで上位N位の最大値を取得するにはどうすればよいですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2025-01-09 14:01:40639ブラウズ

How to Retrieve the Top N Highest Values in Oracle SQL?

Oracle SQL での上位 N 位の最大値の抽出

課題: Oracle SQL クエリ内の特定の列から最大値を含む特定の数の行を効率的に選択するにはどうすればよいですか?

解決策:

最適なアプローチでは、Oracle の分析関数、具体的には RANK() または DENSE_RANK():

を利用します。

RANK() 関数の使用:

<code class="language-sql">select * from (
  select empno, sal, rank() over (order by sal desc) as rnk
  from emp
)
where rnk <= 5;</code>

このクエリは、給与の上位 5 位と、対応する従業員数を取得します。

DENSE_RANK() 関数の使用:

<code class="language-sql">select * from (
  select empno, sal, dense_rank() over (order by sal desc) as rnk
  from emp
)
where rnk <= 5;</code>

DENSE_RANK() は、複数の行が同じ値を共有する場合にランキングのギャップを排除することで、RANK() よりも有利になります。

重要な考慮事項:

  • ROW_NUMBER() 分析関数でもこれを実現できますが、一般に、RANK() または DENSE_RANK() は、タイをより適切に処理するため、上位 N 値を選択する場合に好まれます。
  • ROWNUM 疑似列をスタンドアロン ソリューションとして使用することは避けてください。 句の ORDER BYに適用すると、不正確な結果が生じる可能性があります。

以上がOracle SQLで上位N位の最大値を取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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