ストアドプロシージャとファンクションの違い

Anonim

ストアドプロシージャーと関数

ストアドプロシージャーと関数は2種類のプログラミングブロックです。どちらも呼び出し元の名前が必要です。これらの呼び出し元の名前は、プロシージャのファンクションやパッケージ、SQL問合せなどの別のプログラミング・ブロック内で呼び出すために使用されます。これらのオブジェクトタイプは両方ともパラメータを受け取り、それらのオブジェクトの背後にあるタスクを実行します。これは、ストアドプロシージャを作成する構文(ORACLE内)です。

プロシージャprocedurename(parameters)

begin

文として作成または置換します。

例外

例外処理

終了;

次に、(ORACLEの)関数を作成するための構文を示します。

<! - >

関数を作成または置換する(パラメータ)

return return_datatype

begin

ステートメントとして返す。

戻り値return_value / variable;

例外。

exception_handling;

終了;

ストアドプロシージャ

上述したように、ストアドプロシージャは名前付きプログラミングブロックである。プロシージャの背後にあるロジックに従ってパラメータをユーザー入力とプロセスとして受け取り、結果を与える(または特定のアクションを実行する)。これらのパラメータにはIN、OUT、INOUT型があります。変数宣言、変数代入、制御文、ループ、SQL照会、その他の関数/プロシージャ/パッケージ呼び出しは、プロシージャの本体内に置くことができます。

関数

関数はまた、RETURNステートメントを使用して値を返さなければならない名前付きプログラミングブロックであり、値を返す前に、本体は(指定されたロジックに従って)いくつかのアクションも実行します。関数は、実行するパラメータも受け入れます。関数はクエリ内で呼び出すことができます。関数がSELECT問合せ内で呼び出されると、SELECT問合せの結果セットの各行に適用されます。 ORACLE関数にはいくつかのカテゴリがあります。

  • 単一行関数(問合せの各行ごとに単一の結果を戻します)

単一行関数のサブカテゴリがあります。

  • 日付関数(例:LAST_DAY、NEXT_DAY)
  • 変換関数(例:TO_CHAR、TO_DATE) )集計関数(例:CARDINALITY、SET)
  • 集計関数(行のグループに基づいて単一行を返す例:AVG、SUM、MAX)
  • 解析関数
  • オブジェクト参照関数
  • モデル関数
  • ユーザー定義関数
  • 関数とストアドプロシージャの違いは何ですか?
  • •すべての関数は、RETURN文を使用して値を返す必要があります。ストアド・プロシージャは、RETURN文を使用して値を戻しません。プロシージャ内のRETURN文は、その制御を呼び出し側のプログラムに戻します。 OUTパラメーターを使用して、ストアード・プロシージャーから値を戻すことができます。
  • •クエリ内で関数を呼び出すことはできますが、ストアドプロシージャをクエリ内で使用することはできません。

•関数を作成するにはRETURNデータ型をインクルードする必要がありますが、ストアド・プロシージャDDLではそうではありません。