PL / SQL - Fonctions

Dans ce chapitre, nous aborderons les fonctions en PL / SQL. Une fonction est identique à une procédure, sauf qu'elle renvoie une valeur. Par conséquent, toutes les discussions du chapitre précédent sont également valables pour les fonctions.

Créer une fonction

Une fonction autonome est créée à l'aide du CREATE FUNCTIONdéclaration. La syntaxe simplifiée pour leCREATE OR REPLACE PROCEDURE la déclaration est la suivante -

CREATE [OR REPLACE] FUNCTION function_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
RETURN return_datatype 
{IS | AS} 
BEGIN 
   < function_body > 
END [function_name];

Où,

  • nom-fonction spécifie le nom de la fonction.

  • L'option [OR REPLACE] permet la modification d'une fonction 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.

  • La fonction doit contenir un return déclaration.

  • La clause RETURN spécifie le type de données que vous allez renvoyer à partir de la fonction.

  • function-body contient la partie exécutable.

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

Exemple

L'exemple suivant illustre comment créer et appeler une fonction autonome. Cette fonction renvoie le nombre total de CLIENTS dans la table des clients.

Nous utiliserons la table CUSTOMERS, que nous avions créée dans le chapitre Variables PL / SQL -

Select * from customers; 
 
+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+
CREATE OR REPLACE FUNCTION totalCustomers 
RETURN number IS 
   total number(2) := 0; 
BEGIN 
   SELECT count(*) into total 
   FROM customers; 
    
   RETURN total; 
END; 
/

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

Function created.

Appeler une fonction

Lors de la création d'une fonction, vous donnez une définition de ce que la fonction doit faire. Pour utiliser une fonction, vous devrez appeler cette fonction pour exécuter la tâche définie. Lorsqu'un programme appelle une fonction, le contrôle du programme est transféré à la fonction appelée.

Une fonction appelée exécute la tâche définie et lorsque son instruction return est exécutée ou lorsque le last end statement est atteint, il ramène le contrôle du programme au programme principal.

Pour appeler une fonction, vous devez simplement transmettre les paramètres requis avec le nom de la fonction et si la fonction renvoie une valeur, vous pouvez stocker la valeur renvoyée. Le programme suivant appelle la fonctiontotalCustomers à partir d'un bloc anonyme -

DECLARE 
   c number(2); 
BEGIN 
   c := totalCustomers(); 
   dbms_output.put_line('Total no. of Customers: ' || c); 
END; 
/

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

Total no. of Customers: 6  

PL/SQL procedure successfully completed.

Exemple

L'exemple suivant illustre la déclaration, la définition et l'appel d'une fonction PL / SQL simple qui calcule et renvoie le maximum de deux valeurs.

DECLARE 
   a number; 
   b number; 
   c number; 
FUNCTION findMax(x IN number, y IN number)  
RETURN number 
IS 
    z number; 
BEGIN 
   IF x > y THEN 
      z:= x; 
   ELSE 
      Z:= y; 
   END IF;  
   RETURN z; 
END; 
BEGIN 
   a:= 23; 
   b:= 45;  
   c := findMax(a, b); 
   dbms_output.put_line(' Maximum of (23,45): ' || c); 
END; 
/

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

Maximum of (23,45): 45   

PL/SQL procedure successfully completed.

Fonctions récursives PL / SQL

Nous avons vu qu'un programme ou sous-programme peut appeler un autre sous-programme. Lorsqu'un sous-programme s'appelle lui-même, il est appelé appel récursif et le processus est appelérecursion.

Pour illustrer le concept, calculons la factorielle d'un nombre. La factorielle d'un nombre n est définie comme -

n! = n*(n-1)! 
   = n*(n-1)*(n-2)! 
      ... 
   = n*(n-1)*(n-2)*(n-3)... 1

Le programme suivant calcule la factorielle d'un nombre donné en s'appelant récursivement -

DECLARE 
   num number; 
   factorial number;  
   
FUNCTION fact(x number) 
RETURN number  
IS 
   f number; 
BEGIN 
   IF x=0 THEN 
      f := 1; 
   ELSE 
      f := x * fact(x-1); 
   END IF; 
RETURN f; 
END;  

BEGIN 
   num:= 6; 
   factorial := fact(num); 
   dbms_output.put_line(' Factorial '|| num || ' is ' || factorial); 
END; 
/

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

Factorial 6 is 720 
  
PL/SQL procedure successfully completed.