ホームページ >運用・保守 >Linuxの運用と保守 >Oracle データベースのストアド プロシージャについて話しましょう

Oracle データベースのストアド プロシージャについて話しましょう

PHPz
PHPzオリジナル
2023-04-17 10:28:44772ブラウズ

Oracle データベースでは、ストアド プロシージャは、他のプログラムまたはアプリケーションから呼び出すことができる再利用可能なコード ブロックです。ストアド プロシージャは、パラメータの受け取り、複数の SQL ステートメントの実行、データの処理と計算、ループ内の特定のコードの実行などを行うことができます。ストアド プロシージャは 1 つ以上の SQL ステートメントで構成されており、データベースと繰り返し対話することなく、1 回の実行で複数の SQL ステートメントを実行できます。

ストアド プロシージャは、トランザクションのアトミック性と一貫性を確保するために、複雑なトランザクションの一部としてよく使用されます。複雑なトランザクション内で複数の SQL ステートメントを実行すると、エラーや一貫性のない結果が発生する可能性があります。ただし、これらの SQL ステートメントをストアド プロシージャで結合すると、これらのステートメントがアトミックに実行されることを保証できます。つまり、すべてのステートメントが正常に実行されるか、すべてのステートメントがロールバックされます。さらに、ストアド プロシージャを使用すると、実行効率が向上し、SQL ステートメントが実行されるたびに接続を確立したり閉じたりするオーバーヘッドを回避できます。

ストアド プロシージャを作成するための構文は次のとおりです。

CREATE [OR REPLACE] PROCEDURE procedure_name
(parameter1 [IN | OUT | IN OUT] type1,
 parameter2 [IN | OUT | IN OUT] type2,
 ...
 parameterN [IN | OUT | IN OUT] typeN)
IS
[local_variable_declarations;]

BEGIN
 SQL_statements;
 [EXCEPTION
   exception_section;]

END [procedure_name];

その中には次のものが含まれます。

  • procedure_name: ストアド プロシージャの名前。
  • parameter1、parameter2、…parameterN: ストアド プロシージャのパラメータ。
  • type1、type2、…typeN: パラメータのデータ型。
  • local_variable_declarations: ストアド プロシージャ内のローカル変数の宣言。ストアド プロシージャ内での計算または処理に使用されます。
  • SQL_statements: ストアド プロシージャの実際の実行バッチ SQL ステートメント。
  • Exception_section: ストアド プロシージャ内の例外ハンドラー。

次に、ストアド プロシージャの使用例を示します。

CREATE OR REPLACE PROCEDURE get_all_employees
IS
BEGIN
  SELECT * FROM employees;
END;

このストアド プロシージャは get_all_employees という名前でパラメータはなく、その目的はすべての従業員レコードを返すことです。このストアド プロシージャが実行されると、すべての従業員レコードが返されます。

ストアド プロシージャでは、条件ステートメント、ループ ステートメント、カーソル、例外処理などの関数も使用できます。次に、より複雑な例を示します。

CREATE OR REPLACE PROCEDURE calculate_salary
(
  in_emp_id IN employees.employee_id%TYPE,
  out_salary OUT NUMBER
)
IS
  emp_name employees.last_name%TYPE;
  emp_salary employees.salary%TYPE;
BEGIN
  SELECT last_name, salary INTO emp_name, emp_salary
  FROM employees
  WHERE employee_id = in_emp_id;

  IF emp_salary > 5000 THEN
    out_salary := emp_salary * 1.2;
  ELSE
    out_salary := emp_salary * 1.1;
  END IF;

  DBMS_OUTPUT.PUT_LINE('员工姓名: ' || emp_name);
  DBMS_OUTPUT.PUT_LINE('原薪资: ' || emp_salary);
  DBMS_OUTPUT.PUT_LINE('计算后薪资: ' || out_salary);
EXCEPTION
  WHEN NO_DATA_FOUND THEN
    DBMS_OUTPUT.PUT_LINE('员工ID未找到。');
END;

このストアド プロシージャのパラメータには、入力パラメータemployee_idと出力パラメータsalalalが含まれます。ストアド プロシージャの機能は、employee_id パラメータに基づいて従業員レコードを取得し、従業員の給与を計算し、out_salary パラメータに値を割り当てることです。指定されたemployee_idが存在しない場合、ストアド プロシージャは例外をスローします。

ストアド プロシージャは、データベースの効率とセキュリティを向上させるだけでなく、アプリケーションをよりモジュール化し、コードの再利用性を向上させます。ストアド プロシージャを作成してデータベースに保存し、すべてのアプリケーションで使用できるようにします。さらに、ストアド プロシージャを定期的に実行して、データのバックアップやアーカイブなどの特定のバックグラウンド タスクを実行することもできます。

一般に、Oracle データベース ストアド プロシージャは、複雑なデータベースの動作やトランザクションを処理するために使用できる強力で柔軟なツールです。ストアドプロシージャを再利用できるため、当然データベースシステム全体の効率が向上し、データベースのパフォーマンスが向上します。したがって、ストアド プロシージャの作成方法を学ぶことは、キャリア開発に大きく役立ちます。

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

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