PL / SQL - Procédures

Dans ce chapitre, nous aborderons les procédures en PL / SQL. UNEsubprogramest une unité / module de programme qui exécute une tâche particulière. Ces sous-programmes sont combinés pour former des programmes plus vastes. C'est ce qu'on appelle fondamentalement la «conception modulaire». Un sous-programme peut être appelé par un autre sous-programme ou programme appelécalling program.

Un sous-programme peut être créé -

  • Au niveau du schéma
  • À l'intérieur d'un colis
  • À l'intérieur d'un bloc PL / SQL

Au niveau du schéma, le sous-programme est un standalone subprogram. Il est créé avec l'instruction CREATE PROCEDURE ou CREATE FUNCTION. Il est stocké dans la base de données et peut être supprimé avec l'instruction DROP PROCEDURE ou DROP FUNCTION.

Un sous-programme créé à l'intérieur d'un package est un packaged subprogram. Il est stocké dans la base de données et ne peut être supprimé que lorsque le package est supprimé avec l'instruction DROP PACKAGE. Nous discuterons des packages dans le chapitre'PL/SQL - Packages'.

Les sous-programmes PL / SQL sont appelés blocs PL / SQL qui peuvent être appelés avec un ensemble de paramètres. PL / SQL fournit deux types de sous-programmes -

  • Functions- Ces sous-programmes renvoient une valeur unique; principalement utilisé pour calculer et renvoyer une valeur.

  • Procedures- Ces sous-programmes ne renvoient pas de valeur directement; principalement utilisé pour effectuer une action.

Ce chapitre couvrira des aspects importants d'une PL/SQL procedure. Nous discuteronsPL/SQL function dans le chapitre suivant.

Parties d'un sous-programme PL / SQL

Chaque sous-programme PL / SQL a un nom et peut également avoir une liste de paramètres. Comme les blocs PL / SQL anonymes, les blocs nommés auront également les trois parties suivantes -

S. Non Pièces et description
1

Declarative Part

C'est une partie optionnelle. Cependant, la partie déclarative d'un sous-programme ne commence pas par le mot clé DECLARE. Il contient des déclarations de types, curseurs, constantes, variables, exceptions et sous-programmes imbriqués. Ces éléments sont locaux au sous-programme et cessent d'exister lorsque le sous-programme termine l'exécution.

2

Executable Part

Il s'agit d'une partie obligatoire et contient des instructions qui exécutent l'action désignée.

3

Exception-handling

C'est encore une partie optionnelle. Il contient le code qui gère les erreurs d'exécution.

Créer une procédure

Une procédure est créée avec le CREATE OR REPLACE PROCEDUREdéclaration. La syntaxe simplifiée de l'instruction CREATE OR REPLACE PROCEDURE est la suivante:

CREATE [OR REPLACE] PROCEDURE procedure_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
{IS | AS} 
BEGIN 
  < procedure_body > 
END procedure_name;

Où,

  • nom_procédure spécifie le nom de la procédure.

  • L'option [OR REPLACE] permet la modification d'une procédure existante.

  • La liste des paramètres facultatifs contient le nom, le mode et les types des paramètres. IN représente la valeur qui sera transmise de l'extérieur et OUT représente le paramètre qui sera utilisé pour renvoyer une valeur en dehors de la procédure.

  • procedure-body contient la partie exécutable.

  • Le mot clé AS est utilisé à la place du mot clé IS pour créer une procédure autonome.

Exemple

L'exemple suivant crée une procédure simple qui affiche la chaîne "Hello World!" sur l'écran lors de l'exécution.

CREATE OR REPLACE PROCEDURE greetings 
AS 
BEGIN 
   dbms_output.put_line('Hello World!'); 
END; 
/

Lorsque le code ci-dessus est exécuté à l'aide de l'invite SQL, il produira le résultat suivant -

Procedure created.

Exécution d'une procédure autonome

Une procédure autonome peut être appelée de deux manières:

  • En utilisant le EXECUTE mot-clé

  • Appeler le nom de la procédure à partir d'un bloc PL / SQL

La procédure ci-dessus nommée 'greetings' peut être appelé avec le mot-clé EXECUTE comme -

EXECUTE greetings;

L'appel ci-dessus affichera -

Hello World

PL/SQL procedure successfully completed.

La procédure peut également être appelée depuis un autre bloc PL / SQL -

BEGIN 
   greetings; 
END; 
/

L'appel ci-dessus affichera -

Hello World  

PL/SQL procedure successfully completed.

Suppression d'une procédure autonome

Une procédure autonome est supprimée avec le DROP PROCEDUREdéclaration. La syntaxe pour supprimer une procédure est -

DROP PROCEDURE procedure-name;

Vous pouvez supprimer la procédure de message d'accueil en utilisant l'instruction suivante -

DROP PROCEDURE greetings;

Modes de paramètres dans les sous-programmes PL / SQL

Le tableau suivant répertorie les modes de paramètres dans les sous-programmes PL / SQL -

S. Non Mode de paramètre et description
1

IN

Un paramètre IN vous permet de transmettre une valeur au sous-programme. It is a read-only parameter. À l'intérieur du sous-programme, un paramètre IN agit comme une constante. Il ne peut pas recevoir de valeur. Vous pouvez transmettre une constante, un littéral, une variable initialisée ou une expression en tant que paramètre IN. Vous pouvez également l'initialiser à une valeur par défaut; cependant, dans ce cas, il est omis de l'appel de sous-programme.It is the default mode of parameter passing. Parameters are passed by reference.

2

OUT

Un paramètre OUT renvoie une valeur au programme appelant. À l'intérieur du sous-programme, un paramètre OUT agit comme une variable. Vous pouvez modifier sa valeur et référencer la valeur après l'avoir affectée.The actual parameter must be variable and it is passed by value.

3

IN OUT

Un IN OUTLe paramètre transmet une valeur initiale à un sous-programme et renvoie une valeur mise à jour à l'appelant. Une valeur peut lui être attribuée et la valeur peut être lue.

Le paramètre réel correspondant à un paramètre formel IN OUT doit être une variable et non une constante ou une expression. Une valeur doit être attribuée au paramètre formel.Actual parameter is passed by value.

Exemple de mode IN & OUT 1

Ce programme trouve le minimum de deux valeurs. Ici, la procédure prend deux nombres en utilisant le mode IN et renvoie leur minimum en utilisant les paramètres OUT.

DECLARE 
   a number; 
   b number; 
   c number;
PROCEDURE findMin(x IN number, y IN number, z OUT number) IS 
BEGIN 
   IF x < y THEN 
      z:= x; 
   ELSE 
      z:= y; 
   END IF; 
END;   
BEGIN 
   a:= 23; 
   b:= 45; 
   findMin(a, b, c); 
   dbms_output.put_line(' Minimum of (23, 45) : ' || c); 
END; 
/

Lorsque le code ci-dessus est exécuté à l'invite SQL, il produit le résultat suivant -

Minimum of (23, 45) : 23  

PL/SQL procedure successfully completed.

Exemple de mode IN & OUT 2

Cette procédure calcule le carré de la valeur d'une valeur passée. Cet exemple montre comment utiliser le même paramètre pour accepter une valeur, puis renvoyer un autre résultat.

DECLARE 
   a number; 
PROCEDURE squareNum(x IN OUT number) IS 
BEGIN 
  x := x * x; 
END;  
BEGIN 
   a:= 23; 
   squareNum(a); 
   dbms_output.put_line(' Square of (23): ' || a); 
END; 
/

Lorsque le code ci-dessus est exécuté à l'invite SQL, il produit le résultat suivant -

Square of (23): 529 

PL/SQL procedure successfully completed.

Méthodes de transmission des paramètres

Les paramètres réels peuvent être transmis de trois manières -

  • Notation positionnelle
  • Notation nommée
  • Notation mixte

Notation positionnelle

En notation positionnelle, vous pouvez appeler la procédure comme -

findMin(a, b, c, d);

En notation positionnelle, le premier paramètre réel est remplacé par le premier paramètre formel; le deuxième paramètre réel est remplacé par le deuxième paramètre formel, et ainsi de suite. Alors,a se substitue à x, b se substitue à y, c se substitue à z et d se substitue à m.

Notation nommée

Dans la notation nommée, le paramètre réel est associé au paramètre formel à l'aide de la arrow symbol ( => ). L'appel de procédure sera comme suit -

findMin(x => a, y => b, z => c, m => d);

Notation mixte

En notation mixte, vous pouvez mélanger les deux notations dans l'appel de procédure; cependant, la notation positionnelle doit précéder la notation nommée.

L'appel suivant est légal -

findMin(a, b, c, m => d);

Cependant, ce n'est pas légal:

findMin(x => a, b, c, d);