Oracle SQL: 上位 5 つの最大値の抽出
多くのデータベース タスクでは、列の最大値または最小値に基づいて特定の行数を取得する必要があります。 これは、トップパフォーマーを特定したり、レポートを作成したりする場合に特に役立ちます。この記事では、列から上位 5 つの値を取得するためのいくつかの Oracle SQL メソッドを示します。
分析関数の使用: RANK()
および DENSE_RANK()
分析関数は効率的な行ランキングを提供します。 RANK()
は、指定された基準に基づいて一意のランクを割り当てます。一方、DENSE_RANK()
は同様の機能を提供しますが、同順位のランキングのギャップを排除します。
RANK()
を使用して「emp」テーブルの「sal」列から上位 5 件の給与を取得するには:
<code class="language-sql">SELECT * FROM ( SELECT empno, sal, RANK() OVER (ORDER BY sal DESC) AS rnk FROM emp ) WHERE rnk <= 5;</code>
ROW_NUMBER()
ROW_NUMBER()
関数は、順序に関係なく、各行に連続番号を割り当てます。 これにより、結果を特定の行数に制限できます。
ROW_NUMBER()
を使用して上位 5 位の給与を取得する方法は次のとおりです:
<code class="language-sql">SELECT * FROM ( SELECT empno, sal, ROW_NUMBER() OVER (ORDER BY sal DESC) AS rnk FROM emp ) WHERE rnk <= 5;</code>
代替アプローチ: ROWNUM
疑似列
ROWNUM
疑似列は、クエリ結果の物理行番号を提供します。 ただし、結果を制限する目的での使用は、矛盾が生じる可能性があるため、一般的に推奨されません。
ROWNUM
を使用した例:
<code class="language-sql">SELECT * FROM ( SELECT empno, sal FROM emp ORDER BY sal DESC ) WHERE ROWNUM <= 5;</code>
適切な方法の選択
最適なアプローチは、特定のニーズとデータの特性によって異なります。
RANK()
と DENSE_RANK()
は、同点であってもランキング順序を維持します。ROW_NUMBER()
は特定の行数を保証しますが、同点の結果は任意に切り捨てられる可能性があります。ROWNUM
は信頼性が低いため、慎重に使用する必要があります。Oracle SQL で正確かつ一貫したデータを取得するには、これらのメソッドを慎重に検討することが重要です。
以上がOracle SQLで上位5つの列値を取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。