PL / SQL - Exceptions

Dans ce chapitre, nous aborderons les exceptions en PL / SQL. Une exception est une condition d'erreur lors de l'exécution d'un programme. PL / SQL aide les programmeurs à détecter ces conditions en utilisantEXCEPTIONbloc dans le programme et une action appropriée est prise contre la condition d'erreur. Il existe deux types d'exceptions -

  • Exceptions définies par le système
  • Exceptions définies par l'utilisateur

Syntaxe pour la gestion des exceptions

La syntaxe générale de la gestion des exceptions est la suivante. Ici, vous pouvez lister autant d'exceptions que vous pouvez gérer. L'exception par défaut sera gérée en utilisantWHEN others THEN -

DECLARE 
   <declarations section> 
BEGIN 
   <executable command(s)> 
EXCEPTION 
   <exception handling goes here > 
   WHEN exception1 THEN  
      exception1-handling-statements  
   WHEN exception2  THEN  
      exception2-handling-statements  
   WHEN exception3 THEN  
      exception3-handling-statements 
   ........ 
   WHEN others THEN 
      exception3-handling-statements 
END;

Exemple

Écrivons un code pour illustrer le concept. Nous utiliserons la table CUSTOMERS que nous avons créée et utilisée dans les chapitres précédents -

DECLARE 
   c_id customers.id%type := 8; 
   c_name customerS.Name%type; 
   c_addr customers.address%type; 
BEGIN 
   SELECT  name, address INTO  c_name, c_addr 
   FROM customers 
   WHERE id = c_id;  
   DBMS_OUTPUT.PUT_LINE ('Name: '||  c_name); 
   DBMS_OUTPUT.PUT_LINE ('Address: ' || c_addr); 

EXCEPTION 
   WHEN no_data_found THEN 
      dbms_output.put_line('No such customer!'); 
   WHEN others THEN 
      dbms_output.put_line('Error!'); 
END; 
/

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

No such customer!  

PL/SQL procedure successfully completed.

Le programme ci-dessus affiche le nom et l'adresse d'un client dont l'ID est donné. Puisqu'il n'y a aucun client avec la valeur d'ID 8 dans notre base de données, le programme lève l'exception d'exécutionNO_DATA_FOUND, qui est capturé dans le EXCEPTION block.

Lever des exceptions

Les exceptions sont déclenchées automatiquement par le serveur de base de données chaque fois qu'il y a une erreur de base de données interne, mais les exceptions peuvent être déclenchées explicitement par le programmeur à l'aide de la commande RAISE. Voici la syntaxe simple pour lever une exception -

DECLARE 
   exception_name EXCEPTION; 
BEGIN 
   IF condition THEN 
      RAISE exception_name; 
   END IF; 
EXCEPTION 
   WHEN exception_name THEN 
   statement; 
END;

Vous pouvez utiliser la syntaxe ci-dessus pour déclencher l'exception standard Oracle ou toute exception définie par l'utilisateur. Dans la section suivante, nous vous donnerons un exemple sur la levée d'une exception définie par l'utilisateur. Vous pouvez lever les exceptions standard Oracle de la même manière.

Exceptions définies par l'utilisateur

PL / SQL vous permet de définir vos propres exceptions en fonction des besoins de votre programme. Une exception définie par l'utilisateur doit être déclarée puis déclenchée explicitement, à l'aide d'une instruction RAISE ou de la procédureDBMS_STANDARD.RAISE_APPLICATION_ERROR.

La syntaxe pour déclarer une exception est -

DECLARE 
   my-exception EXCEPTION;

Exemple

L'exemple suivant illustre le concept. Ce programme demande un identifiant client, lorsque l'utilisateur entre un identifiant invalide, l'exceptioninvalid_id est soulevé.

DECLARE 
   c_id customers.id%type := &cc_id; 
   c_name customerS.Name%type; 
   c_addr customers.address%type;  
   -- user defined exception 
   ex_invalid_id  EXCEPTION; 
BEGIN 
   IF c_id <= 0 THEN 
      RAISE ex_invalid_id; 
   ELSE 
      SELECT  name, address INTO  c_name, c_addr 
      FROM customers 
      WHERE id = c_id;
      DBMS_OUTPUT.PUT_LINE ('Name: '||  c_name);  
      DBMS_OUTPUT.PUT_LINE ('Address: ' || c_addr); 
   END IF; 

EXCEPTION 
   WHEN ex_invalid_id THEN 
      dbms_output.put_line('ID must be greater than zero!'); 
   WHEN no_data_found THEN 
      dbms_output.put_line('No such customer!'); 
   WHEN others THEN 
      dbms_output.put_line('Error!');  
END; 
/

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

Enter value for cc_id: -6 (let's enter a value -6) 
old  2: c_id customers.id%type := &cc_id; 
new  2: c_id customers.id%type := -6; 
ID must be greater than zero! 
 
PL/SQL procedure successfully completed.

Exceptions prédéfinies

PL / SQL fournit de nombreuses exceptions prédéfinies, qui sont exécutées lorsqu'une règle de base de données est violée par un programme. Par exemple, l'exception prédéfinie NO_DATA_FOUND est déclenchée lorsqu'une instruction SELECT INTO ne renvoie aucune ligne. Le tableau suivant répertorie quelques-unes des exceptions prédéfinies importantes -

Exception Erreur Oracle SQLCODE La description
ACCESS_INTO_NULL 06530 -6530 Il est déclenché lorsqu'un objet nul reçoit automatiquement une valeur.
CASE_NOT_FOUND 06592 -6592 Il est déclenché lorsqu'aucun des choix de la clause WHEN d'une instruction CASE n'est sélectionné et qu'il n'y a pas de clause ELSE.
COLLECTION_IS_NULL 06531 -6531 Il est déclenché lorsqu'un programme tente d'appliquer des méthodes de collecte autres que EXISTS à une table imbriquée ou varray non initialisée, ou lorsque le programme tente d'affecter des valeurs aux éléments d'une table imbriquée ou varray non initialisée.
DUP_VAL_ON_INDEX 00001 -1 Il est déclenché lorsque des valeurs en double sont tentées d'être stockées dans une colonne avec un index unique.
INVALID_CURSOR 01001 -1001 Il est déclenché lorsque des tentatives sont effectuées pour effectuer une opération de curseur non autorisée, comme la fermeture d'un curseur non ouvert.
NUMÉRO INVALIDE 01722 -1722 Il est déclenché lorsque la conversion d'une chaîne de caractères en un nombre échoue car la chaîne ne représente pas un nombre valide.
LOGIN_DENIED 01017 -1017 Il est déclenché lorsqu'un programme tente de se connecter à la base de données avec un nom d'utilisateur ou un mot de passe non valide.
AUCUNE DONNÉE DISPONIBLE 01403 +100 Il est déclenché lorsqu'une instruction SELECT INTO ne renvoie aucune ligne.
NOT_LOGGED_ON 01012 -1012 Il est déclenché lorsqu'un appel de base de données est émis sans être connecté à la base de données.
PROGRAM_ERROR 06501 -6501 Il est déclenché lorsque PL / SQL a un problème interne.
ROWTYPE_MISMATCH 06504 -6504 Il est déclenché lorsqu'un curseur récupère une valeur dans une variable de type de données incompatible.
SELF_IS_NULL 30625 -30625 Il est déclenché lorsqu'une méthode membre est appelée, mais que l'instance du type d'objet n'a pas été initialisée.
STORAGE_ERROR 06500 -6500 Il est déclenché lorsque PL / SQL a manqué de mémoire ou que la mémoire a été corrompue.
TOO_MANY_ROWS 01422 -1422 Il est déclenché lorsqu'une instruction SELECT INTO renvoie plus d'une ligne.
VALUE_ERROR 06502 -6502 Il est déclenché lorsqu'une erreur d'arithmétique, de conversion, de troncature ou de contrainte de taille se produit.
ZERO_DIVIDE 01476 1476 Il est déclenché lorsqu'une tentative est faite pour diviser un nombre par zéro.