Rechercher : dans
Par :

[PL/SQL] Continuer malgré une Exception

Dernière réponse le 19 nov 2009 à 09:58:05 Pillou, le 6 mai 2009 à 08:42:02 
 Signaler ce message aux modérateurs

Bonjour,

j'ai réalisé un programme en PL/SQL et je me heurte à un souci : continuer dans le bloc qui a générer une exception après déclenchement de celle ci. Voici en gros la structure du programme :

Declare
.....

BEGIN

boucle de Curseur

Instruction 1
Instruction 2
Instruction 3
Instruction 4

fin boucle de Curseur

Exception
when ....

END


Ce que je souhaite faire, c'est : si Instruction 1 génére une erreur, envoyer l'erreur dans un log et continuer sur Instruction 2. Et aisnsi de suite.

Merci de votre aide.

Configuration: Windows XP Internet Explorer 6.0

Meilleures réponses pour « [PL/SQL] Continuer malgré une Exception » dans :
PL/SQL - Introduction au langage PL/SQL Voir Introduction au langage PL/SQL Le langage PL/SQL est un langage L4G (entendez par ce terme un langage de quatrième génération), fournissant une interface procédurale au SGBD Oracle. Le langage PL/SQL intègre parfaitement le langage SQL en lui...

1

sandul, le 6 mai 2009 à 08:56:22

Salut,

Tu peux entourer chacune de tes instructions par un bloc try..catch à la sauce PL/SQL. Exemple:

BEGIN
   Instruction 1;
EXCEPTION
   WHEN OTHERS
   THEN
      -- Tu traites ici la journalisation pour les erreurs générées
      -- par le traitement de l'Instruction 1.
      -- Tu peux utiliser par exemple le package UTL_FILE
      -- pour écrire dans un fichier.
END;


++

Répondre à sandul

2

Pillou, le 6 mai 2009 à 09:15:58

Merci mais j'ai bien essayé d'entourer les instructions mais PL/SQL ne veut pas.
Il m'empêche de faire :

Instruction 1
Exception
when others ...

Instruction 2
Exception
when others ...

Instruction 3
Exception
when others ...

Le problème c'est qu'avec la structure du 1er post (exception à la fin), dès qu'il y a un erreur, il l'a gère et stoppe l'exécution. Or je souhaite qu'il reprenne juste après l'arrêt.

Répondre à Pillou

3

sandul, le 6 mai 2009 à 09:44:05

Merci mais j'ai bien essayé d'entourer les instructions mais PL/SQL ne veut pas. ==>

Sûrement une erreur de syntaxe... Relis bien mon bout de code exemple et fais attention à bien entourer chaque instruction par un BEGIN ... EXCEPTION WHEN OTHERS ...;

Même si tu décides de garder le bloc try..catch global (celui en place actuellement, qui entoure toutes les instructions), tu peux très bien avoir de try..catch imbriqués.

++

Répondre à sandul

4

Pillou, le 6 mai 2009 à 10:13:06

Super ça marche !

merci beaucoup. Je n'avais pas mis de BEGIN :)

+++

Répondre à Pillou

5

sandul, le 6 mai 2009 à 10:15:08

;-)

Répondre à sandul

6

habibdu70, le 18 nov 2009 à 15:50:12

Bonjour,

Moi mon probleme c'est entre mon begin et l'exeption, j'ai une boucle for, et je n'y arrive pas.
Et dans l'exeption, je ne veux rien faire de spéciale pouvez vous m'aider ?

merci

Répondre à habibdu70

7

sandul, le 18 nov 2009 à 16:28:15

Salut,

Moi mon probleme c'est entre mon begin et l'exeption, j'ai une boucle for, et je n'y arrive pas. ==>

Je ne comprends pas trop...

Et dans l'exeption, je ne veux rien faire de spéciale ==>

Utilise, dans ce cas, l'instruction

NULL;


++

Répondre à sandul

8

habibdu70, le 18 nov 2009 à 22:40:14

Ok merci pour le null,

en fait ce que j'ai envie de faire c'est

for ...

begin

exception

end for

end begin

mon probleme, quand je mets exception à l'exterieur de la boucle for, ça marche mais dès qu'il y a une exception on sort de la boucle.

moi je veux continuer la boucle, j'ai donc pensé mettre l'exception dans la boucle, mais la le code ne veux même pas s'éxecuter.

Je sais pas si tu comprend ce que je veux dire, (demain, je pourrais poster ma requette).

cordialement,

Répondre à habibdu70

9

 sandul, le 19 nov 2009 à 09:58:05

Re,

Oui, je comprends et je confirme... Il faut dans ce cas avoir la structure suivante:

boucle
début traitement
...
catch exception
...
fin traitement
fin boucle

Tu pourras continuer la boucle même si certaines exceptions sont déclenchées pendant le traitement. Tu as des erreurs de compil ou d'exécution ?

Répondre à sandul