ホームページ > データベース > mysql チュートリアル > 注文後にOracleクエリの行を制限する方法は?

注文後にOracleクエリの行を制限する方法は?

Linda Hamilton
リリース: 2025-01-25 08:41:12
オリジナル
297 人が閲覧しました

How to Limit Rows in Oracle Queries After Ordering?

順序付けられたOracleクエリの結果セットを制限

oracleのROWNUMpseudocolumnはmysqlのLIMIT句とは異なります。 ROWNUMは、前に>句が処理される前に割り当てられます。 したがって、ORDER BYを直接使用すると、ROWNUMの順序付け後にが制限されません。これを達成するには、サブクエリを使用します:

このアプローチは、給与(
<code class="language-sql">SELECT *
FROM (SELECT * FROM emp ORDER BY sal DESC)
WHERE ROWNUM <= n;</code>
ログイン後にコピー
)の下降で

テーブルを最初に注文します。次に、外部クエリはempを使用して、出力を上部sal行に制限します。 ROWNUM上限と下限の両方を必要とするより複雑なシナリオの場合、ネストされたサブクエリが必要です。 n

Oracle 12cおよびそれ以降

<code class="language-sql">SELECT *
FROM (SELECT a.*, ROWNUM rnum
      FROM (SELECT * FROM your_table ORDER BY your_column) a
      WHERE ROWNUM <= :MAX_ROW_TO_FETCH)
WHERE rnum >= :MIN_ROW_TO_FETCH;</code>
ログイン後にコピー

Oracle 12c(および後のバージョン)は、

を使用して、より合理化された構文を提供します。

これにより、これにより、FETCH FIRSTが注文した後、結果が最初の10行に直接制限されます。 オフセットを指定するには(例:最初の20行をスキップして次の10を取得します)、OFFSET句を使用してください:

>
<code class="language-sql">SELECT *
FROM sometable
ORDER BY name
FETCH FIRST 10 ROWS ONLY;</code>
ログイン後にコピー

包括的な例とパフォーマンス最適化戦略については、公式のOracleドキュメントを参照してください。

以上が注文後にOracleクエリの行を制限する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート