ホームページ 運用・保守 Linuxの運用と保守 Oracle ページング ストアド プロシージャ

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

May 20, 2023 am 09:53 AM

Oracle は、ストアド プロシージャなどの高度な機能をサポートする強力なデータベース管理システムであり、プログラマが複雑なビジネス ロジックを簡単に作成できるようにします。一部の特定のシナリオでは、大量のデータに対してページング クエリを実行する必要があります。これを実現するには、ページ分割されたストアド プロシージャを作成します。この記事では、Oracle ページング ストアド プロシージャの作成方法を紹介します。

1. 要件分析

Web サイト開発では、ユーザーが送信したデータをページに表示する必要がある状況によく遭遇します。たとえば、テーブル内のすべてのレコードをクエリすると、データベースに深刻なパフォーマンスの負荷がかかり、すべてのレコードを一度にクエリするとユーザー エクスペリエンスに影響を与えます。したがって、データをページに表示する方が良い解決策となります。要件を分析しましょう:

  1. レコードの総数を取得します
  2. 各ページのサイズと現在のページ番号に従って、開始レコードと終了レコードの位置を計算します。
  3. 開始レコードと終了レコードに基づいて必要なデータをクエリする

2. ストアド プロシージャの設計

上記の需要分析に基づいて、以下を設計できます。 Oracle ページング ストアド プロシージャ:

CREATE OR REPLACE PROCEDURE pagination(p_table_name IN VARCHAR2,
                                        p_page_num IN NUMBER,
                                        p_page_size IN NUMBER,
                                        p_total_num OUT NUMBER,
                                        p_cursor OUT SYS_REFCURSOR) IS
  v_start_pos NUMBER;
  v_end_pos NUMBER;
  v_sql_query VARCHAR2(1000);
BEGIN
  SELECT COUNT(*) INTO p_total_num FROM p_table_name;
  v_start_pos := (p_page_num - 1) * p_page_size + 1;
  v_end_pos := v_start_pos + p_page_size - 1;
  v_sql_query := 'SELECT * FROM (SELECT A.*, ROWNUM RN FROM (SELECT * FROM ' || p_table_name || ') A WHERE ROWNUM <= ' || v_end_pos || ') WHERE RN >= ' || v_start_pos;
  OPEN p_cursor FOR v_sql_query;
END;
/
ログイン後にコピー

上記のコードは、テーブル名、ページ番号、各ページのサイズ、レコードの合計数の 4 つのパラメータを受け取ることができる pagination という名前のストアド プロシージャを作成します。このうち、p_cursor は出力パラメータで、クエリ結果のカーソルを返すために使用されます。

3. ストアド プロシージャの説明

  1. SELECT COUNT(*) INTO p_total_num FROM p_table_name;
    このステートメントは、テーブル内のレコードの合計数をクエリし、結果 p_total_num。この変数を通じて、総ページ数と現在のページのレコード範囲を計算できます。
  2. v_start_pos := (p_page_num - 1) * p_page_size 1;
    このステートメントは、ページ番号と各ページのサイズから計算される開始レコードの位置を計算するために使用されます。
  3. v_end_pos := v_start_pos p_page_size - 1;
    このステートメントは、終了レコードの位置を計算するために使用されます。これは、ページ番号と各ページのサイズからも計算されます。
  4. v_sql_query := 'SELECT FROM (SELECT A., ROWNUM RN FROM (SELECT * FROM ' || p_table_name || ') A WHERE ROWNUM <= ' || v_end_pos || ') WHERE RN >= ' || v_start_pos;
    このステートメントはクエリ ステートメントであり、テーブル内の指定された範囲内のデータをクエリするために使用されます。 ROWNUM は、各レコードの行番号を表す Oracle 固有の疑似列です。 ROWNUM を使用してクエリ範囲を制限し、ネストされたクエリを通じて RN 列を追加して、現在のレコードの行番号を表しました。最後に、クエリ結果の範囲は開始位置と終了位置に基づいて制限されます。
  5. OPEN p_cursor FOR v_sql_query
    このステートメントは、クエリ ステートメントを実行し、結果をカーソル p_cursor に保存するために使用されます。このカーソルは、後続のデータ操作と転送に使用できます。

4. テスト ケース

ストアド プロシージャが正しいかどうかを確認するために、テスト テーブルを作成し、そのテーブルにデータを挿入します。 #次に、次のコードを実行してストアド プロシージャをテストします。

CREATE TABLE test(
  id NUMBER(10) PRIMARY KEY,
  name VARCHAR2(50)
);

DECLARE 
  v_id NUMBER;
BEGIN
  FOR i IN 1..100 LOOP
    v_id := i;
    INSERT INTO test(id,name) VALUES(v_id,'name'||v_id);
  END LOOP;
  COMMIT;
END;
/
ログイン後にコピー

上記のコードは、1 ~ 10 レコードの ID と名前の値を出力します。

テスト結果から、作成したページング ストアド プロシージャがレコード範囲を正しく計算でき、クエリ結果も正しいことがわかります。このストアド プロシージャは、データのクエリ時のデータベースへの負荷を効果的に軽減し、同時に一度に大量のデータをクエリすることによって発生するパフォーマンスの問題を回避します。

さらに、実際のニーズに応じてストアド プロシージャ内のパラメーターとクエリ ステートメントを調整して、より複雑なクエリ シナリオに適応することもできます。

5. 概要

Oracle データベースでは、ストアド プロシージャは非常に重要な機能であり、複雑なビジネス ロジックやデータ操作プロセスを記述し、データベース操作の効率と効率を向上させるのに役立ちます。そしてメンテナンス性。この記事では、Oracle ページング ストアド プロシージャの作成方法を紹介します。Oracle ストアド プロシージャの理解に基づいて、要件を分析し、アルゴリズムを設計し、コードを記述することで、単純なページング ストアド プロシージャを実装します。この記事の事例を学ぶことで、読者は Oracle ストアド プロシージャの作成方法とテクニックをよりよく習得できるようになります。

以上が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)

DebianでTigervncのログを表示する場所 DebianでTigervncのログを表示する場所 Apr 13, 2025 am 07:24 AM

Debianシステムでは、Tigervncサーバーのログファイルは通常、ユーザーのホームディレクトリの.VNCフォルダーに保存されます。 Tigervncを特定のユーザーとして実行する場合、ログファイル名は通常XFに似ています。1。Log、XF:1はユーザー名を表します。これらのログを表示するには、次のコマンドを使用できます。CAT〜/.VNC/XF:1。LOGまたは、テキストエディターを使用してログファイルを開くことができます。NANO〜/.VNC/XF:1。LOGログファイルへのアクセスと表示には、システムのセキュリティの設定に応じてルート許可が必要になる場合があります。

主要なLinux操作:初心者向けガイド 主要なLinux操作:初心者向けガイド Apr 09, 2025 pm 04:09 PM

Linuxの初心者は、ファイル管理、ユーザー管理、ネットワーク構成などの基本操作をマスターする必要があります。 1)文件管理:使用mkdir、タッチ、ls rm 3)ネットワーク構成:ifconfig、echo、およびufwコマンドを使用します。これらの操作はLinuxシステム管理の基礎であり、それらをマスターすることでシステムを効果的に管理できます。

Debian Readdirが他のツールと統合する方法 Debian Readdirが他のツールと統合する方法 Apr 13, 2025 am 09:42 AM

DebianシステムのReadDir関数は、ディレクトリコンテンツの読み取りに使用されるシステムコールであり、Cプログラミングでよく使用されます。この記事では、ReadDirを他のツールと統合して機能を強化する方法について説明します。方法1:C言語プログラムを最初にパイプラインと組み合わせて、cプログラムを作成してreaddir関数を呼び出して結果をinclude#include#include inctargc、char*argv []){dir*dir; structdireant*entry; if(argc!= 2){(argc!= 2){

Debian Snifferの出力結果を解釈する方法 Debian Snifferの出力結果を解釈する方法 Apr 12, 2025 pm 11:00 PM

DebiansNifferは、ネットワークパケットタイムスタンプをキャプチャして分析するために使用されるネットワークスニファーツールです。通常、数秒でパケットキャプチャの時間を表示します。ソースIPアドレス(SourceIP):パケットを送信したデバイスのネットワークアドレス。宛先IPアドレス(DestinationIP):データパケットを受信するデバイスのネットワークアドレス。ソースポート:パケットを送信するデバイスで使用されるポート番号。 Destinatio

Debian Mail Server DNSセットアップガイド Debian Mail Server DNSセットアップガイド Apr 13, 2025 am 11:33 AM

Debian Mail ServerのDNS設定を構成するには、次の手順に従うことができます。ネットワーク構成ファイルを開きます。テキストエディター(VIやNANOなど)を使用して、ネットワーク構成ファイル/など/ネットワーク/インターフェイスを開きます。 sudonano/etc/network/interfacesネットワークインターフェイス構成を検索:構成ファイルで変更するネットワークインターフェイスを見つけます。通常、イーサネットインターフェイスの構成はIFETH0ブロックにあります。

使用されなくなったパッケージをリサイクルする方法 使用されなくなったパッケージをリサイクルする方法 Apr 13, 2025 am 08:51 AM

この記事では、役に立たないソフトウェアパッケージをきれいにし、Debianシステムのディスクスペースを解放する方法について説明します。ステップ1:パッケージリストを更新するパッケージリストが最新であることを確認してください:sudoaptupdateステップ2:インストールされたパッケージを表示します。次のコマンドを使用して、すべてのインストールされたパッケージを表示します。適性は、パッケージを安全に削除するのに役立つ提案を提供します:sudoaptitudeSearch '〜pimportant'このコマンドはタグをリストします

DebianがHadoopデータ処理速度を改善する方法 DebianがHadoopデータ処理速度を改善する方法 Apr 13, 2025 am 11:54 AM

この記事では、DebianシステムのHadoopデータ処理効率を改善する方法について説明します。最適化戦略では、ハードウェアのアップグレード、オペレーティングシステムパラメーターの調整、Hadoop構成の変更、および効率的なアルゴリズムとツールの使用をカバーしています。 1.ハードウェアリソースの強化により、すべてのノードが一貫したハードウェア構成、特にCPU、メモリ、ネットワーク機器のパフォーマンスに注意を払うことが保証されます。高性能ハードウェアコンポーネントを選択することは、全体的な処理速度を改善するために不可欠です。 2。オペレーティングシステムチューニングファイル記述子とネットワーク接続:/etc/security/limits.confファイルを変更して、システムによって同時に開くことができるファイル記述子とネットワーク接続の上限を増やします。 JVMパラメーター調整:Hadoop-env.shファイルで調整します

Debian Apacheログを使用してWebサイトのパフォーマンスを向上させる方法 Debian Apacheログを使用してWebサイトのパフォーマンスを向上させる方法 Apr 12, 2025 pm 11:36 PM

この記事では、Debianシステムの下でApacheログを分析することにより、Webサイトのパフォーマンスを改善する方法について説明します。 1.ログ分析の基本Apacheログは、IPアドレス、タイムスタンプ、リクエストURL、HTTPメソッド、応答コードなど、すべてのHTTP要求の詳細情報を記録します。 Debian Systemsでは、これらのログは通常、/var/log/apache2/access.logおよび/var/log/apache2/error.logディレクトリにあります。ログ構造を理解することは、効果的な分析の最初のステップです。 2。ログ分析ツールさまざまなツールを使用してApacheログを分析できます。コマンドラインツール:GREP、AWK、SED、およびその他のコマンドラインツール。

See all articles