ホームページ データベース Oracle Oracle ストアド プロシージャ ページング

Oracle ストアド プロシージャ ページング

May 18, 2023 am 10:19 AM

データベース クエリのパフォーマンスをより最適化するには、ページング クエリにストアド プロシージャを使用するのが良い選択です。ストアド プロシージャを確立すると、大量のデータをクエリするときにページングでリソースを消費できるようになります。 Oracleデータベースには、ページング操作用の実行可能な高度なアルゴリズムがいくつか用意されており、最小限のパーセンテージを使用して必要な結果を取得し、問合せ効率を向上させます。

Oracle では、ストアド プロシージャは、SQL ステートメントをプリコンパイルして保存するために使用できるデータベース オブジェクトです。ストアド プロシージャはパラメータを受け取り、結果を返すことができます。大量のデータを処理する場合、ストアド プロシージャを使用すると、データベース クエリの効率が大幅に向上します。

以下では、Oracle のストアド プロシージャを使用してページング クエリを実装する方法を紹介します。

まず、ページ分割できるようにストアド プロシージャのパラメーターを設定する必要があります。

 CREATE OR REPLACE PROCEDURE paged_results(
  in_table IN VARCHAR2,
  in_where IN VARCHAR2 DEFAULT NULL,
  in_orderby IN VARCHAR2 DEFAULT NULL,
  in_pageSize IN NUMBER DEFAULT 10,
  in_pageNumber IN NUMBER DEFAULT 1,
  out_cursor OUT SYS_REFCURSOR) AS
ログイン後にコピー

このストアド プロシージャは、テーブル名、クエリ条件、並べ替え条件、各ページに表示されるレコード数、およびページ番号の 5 つの入力パラメータを受け入れます。このうち、in_table、in_pageSize、in_pageNumber パラメータは入力する必要がありますが、in_where パラメータと in_orderby パラメータはオプションです。 out_cursor は、各ページのクエリ結果を取得するための出力パラメータとして使用されます。

次に、ストアド プロシージャ内でページネーションを行う方法を検討する必要があります。これが機能の鍵となります。

別のストアド プロシージャを使用してページングを実装できます。以下に示すように、FOR LOOP ループを通じて、データ セット内の指定されたページに含まれるレコードが取得され、返されるレコードの数が計算されます。

cnt := in_pageSize * ( in_pageNumber - 1 );
v_sql := 'select count(*) from ' || in_table ||
         '' || NVL( in_where, '' ) || '';
EXECUTE IMMEDIATE v_sql INTO v_totalRows;
v_totalPages := CEIL( v_totalRows / in_pageSize );
v_currentPage := in_pageNumber;
v_rowCount := 0;
v_startRow := 1;
v_endRow := in_pageSize;
OPEN out_cursor FOR
( SELECT *
  FROM
  (SELECT
    ROW_NUMBER() OVER(ORDER BY tmp_table.row_counter) row_num,
    tmp_table.*
  FROM
    (SELECT
      ROWNUM - 1 + cnt row_counter,
      t.*
    FROM
      ( SELECT
          *
        FROM ' || in_table || 
          NVL( in_where, '' ) ||
          NVL( in_orderby, '' ) || '
      )t
    WHERE
      ROWNUM <= cnt + in_pageSize
    ) tmp_table
  WHERE
    tmp_table.row_counter >= cnt
  )
);
ログイン後にコピー

このストアド プロシージャは、指定されたページ番号のページング結果を返します。2 つのパラメータ in_where と in_orderby は、条件と並べ替え方法を制御するために使用されます。 in_where パラメーターと in_orderby パラメーターが渡されない場合は、条件や順序付けが必要ないことを意味します。

for ループでは、まずデータ セット全体から条件を満たすレコードの数を取得し、次に各ページに表示されるレコードの数に基づいて総ページ数を計算します。指定されたページのデータを取得します。ここでは Row_num を使用し、row_counter を削除します。row_num は行番号を表し、row_counter は連続してカウントされる行の合計数です。最後に、カーソルを開いて、ページ分割された結果セットを返します。

ストアド プロシージャでは、処理を容易にするために、EXECUTE IMMEDIATE ステートメントを使用して SQL ステートメントを動的に実行するため、SQL ステートメントを動的に受け取るように v_sql パラメーターを設定する必要があります。さらに、現在のページ番号、総ページ数、開始行と終了行を保存するには、4 つの共通変数を定義する必要があります。

上記の手順を実行すると、Oracle はページング ロジックを正常に処理できるようになります。これで、PL/SQL でストアド プロシージャを呼び出してデータを取得できるようになりました。

 DECLARE
  CURSOR c_results IS
    SELECT *
      FROM table_name;
  v_result sds.table_name%ROWTYPE;
  in_pageNum NUMBER := 50;
  in_pageSize NUMBER := 10;
  in_orderBy VARCHAR2(100) := ” ORDER BY column_2 ASC”;
  v_string VARCHAR2(100);
  new_cursor SYS_REFCURSOR;
BEGIN
  sds.paged_results(
    in_table_name => 'table_name',
    in_where => 'WHERE column_1 < 50',
    in_orderBy => in_orderBy,
    in_pageSize => in_pageSize,
    in_pageNum => in_pageNum,
    out_cursor => new_cursor);
END;
ログイン後にコピー

上記の例のメソッド呼び出しを通じて、指定されたページのデータを簡単に取得し、結果セットを出力パラメータとして返すことができます。このうち、in_where と in_orderBy は、データ範囲と並べ替え方法の条件を提供できます。

一般に、ページングにストアド プロシージャを使用すると、大量のデータをクエリするときのデータベースのパフォーマンスが向上します。注意する必要があるのは、ストアド プロシージャの動作効率は SQL 記述の品質に関係しており、特定の条件に応じて調整および最適化する必要があるということです。

上記の例を通じて、ストアド プロシージャを使用してページング クエリを実装する基本原則は、ページング パラメーターを設定することでページングを実装する SQL ステートメントを動的に生成することであることが理解できたと思います。ストアド プロシージャを使用すると、データベース クエリの負担が効果的に軽減され、データベース クエリの効率が向上し、サーバー側のリクエストの数が削減されます。

以上がOracle ストアド プロシージャ ページングの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Oracleデータベース操作ツールとは何ですか? Oracleデータベース操作ツールとは何ですか? Apr 11, 2025 pm 03:09 PM

SQL*Plusに加えて、Oracleデータベースを操作するためのツールがあります。SQL開発者:無料ツール、インターフェイスに優しい、グラフィカルな操作とデバッグをサポートします。 Toad:ビジネスツール、機能が豊富で、データベース管理とチューニングに優れています。 PL/SQL開発者:PL/SQL開発、コード編集、デバッグのための強力なツール。 dbeaver:無料のオープンソースツール、複数のデータベースをサポートし、シンプルなインターフェイスを備えています。

Oracleの表空間サイズを確認する方法 Oracleの表空間サイズを確認する方法 Apr 11, 2025 pm 08:15 PM

Oracle Tablespaceサイズを照会するには、次の手順に従ってください。クエリを実行して、TableSpace名を決定します。DBA_TABLESPACesからTableSpace_Nameを選択します。クエリを実行してテーブルスペースのサイズをクエリします:sum(bytes)をtotal_size、sum(bytes_free)asavail_space、sum(bytes) - sum(bytes_free)as sum(bytes_free)as dba_data_files from tablespace_

Oracleデータベースの学習方法 Oracleデータベースの学習方法 Apr 11, 2025 pm 02:54 PM

Oracleデータベースを学習するためのショートカットはありません。データベースの概念を理解し、SQLスキルをマスターし、実践を通じて継続的に改善する必要があります。まず、データベースのストレージおよび管理メカニズムを理解し、テーブル、行、列などの基本概念、およびプライマリキーや外国キーなどの制約をマスターする必要があります。次に、練習を通じて、Oracleデータベースをインストールし、Simple Selectステートメントで練習を開始し、さまざまなSQLステートメントと構文を徐々にマスターします。その後、PL/SQLなどの高度な機能を学習し、SQLステートメントを最適化し、データベースの効率とセキュリティを改善するための効率的なデータベースアーキテクチャを設計できます。

オラクルを開けない場合はどうすればよいですか オラクルを開けない場合はどうすればよいですか Apr 11, 2025 pm 10:06 PM

Oracleのソリューションを開くことはできません。1。データベースサービスを開始します。 2。リスナーを開始します。 3.ポートの競合を確認します。 4.環境変数を正しく設定します。 5.ファイアウォールまたはウイルス対策ソフトウェアが接続をブロックしないことを確認してください。 6.サーバーが閉じているかどうかを確認します。 7. RMANを使用して破損したファイルを回復します。 8。TNSサービス名が正しいかどうかを確認します。 9.ネットワーク接続を確認します。 10。Oracleソフトウェアを再インストールします。

Oracleデータベースの作成方法Oracleデータベースの作成方法 Oracleデータベースの作成方法Oracleデータベースの作成方法 Apr 11, 2025 pm 02:36 PM

Oracleデータベースを作成するには、一般的な方法はDBCAグラフィカルツールを使用することです。手順は次のとおりです。1。DBCAツールを使用してDBNAMEを設定してデータベース名を指定します。 2. SyspasswordとSystemPassWordを強力なパスワードに設定します。 3.文字セットとNationalCharactersetをAL32UTF8に設定します。 4.実際のニーズに応じて調整するようにMemorySizeとTableSpacesizeを設定します。 5. logfileパスを指定します。 高度な方法は、SQLコマンドを使用して手動で作成されますが、より複雑でエラーが発生しやすいです。 パスワードの強度、キャラクターセットの選択、表空間サイズ、メモリに注意してください

Oracle PL/SQL Deep Dive:マスタリング手順、機能、パッケージ Oracle PL/SQL Deep Dive:マスタリング手順、機能、パッケージ Apr 03, 2025 am 12:03 AM

OraclePl/SQLの手順、機能、パッケージは、それぞれ操作、返品値、および整理コードを実行するために使用されます。 1.プロセスは、挨拶の出力などの操作を実行するために使用されます。 2。関数は、2つの数値の合計を計算するなど、値を計算して返すために使用されます。 3.パッケージは、関連する要素を整理し、在庫を管理するパッケージなど、コードのモジュール性と保守性を向上させるために使用されます。

Oracleデータベースの表示方法Oracleデータベースを表示する方法 Oracleデータベースの表示方法Oracleデータベースを表示する方法 Apr 11, 2025 pm 02:48 PM

Oracleデータベースを表示するには、SQL*Plus(Selectコマンドを使用)、SQL開発者(Graphyインターフェイス)、またはシステムビュー(データベースの内部情報の表示)を使用できます。基本的な手順には、データベースへの接続、選択されたステートメントを使用したデータのフィルタリング、パフォーマンスのクエリの最適化が含まれます。さらに、システムビューはデータベースに関する詳細情報を提供し、監視とトラブルシューティングに役立ちます。実践と継続的な学習を通じて、Oracleデータベースの謎を深く探索できます。

Oracleビューを暗号化する方法 Oracleビューを暗号化する方法 Apr 11, 2025 pm 08:30 PM

Oracle View暗号化により、ビュー内のデータを暗号化でき、それにより機密情報のセキュリティが強化されます。手順には以下が含まれます。1)マスター暗号化キー(MEK)の作成。 2)暗号化されたビューを作成し、暗号化されるビューとMEKを指定します。 3)暗号化されたビューにアクセスすることをユーザーに許可します。暗号化されたビューがどのように機能するか:ユーザーが暗号化されたビューを求めてクエリをするとき、OracleはMEKを使用してデータを復号化し、認定ユーザーのみが読み取り可能なデータにアクセスできるようにします。

See all articles