IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

SQL Oracle Discussion :

Pbm Exception DBMS_UTILITY.comma_to_table


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 16
    Par défaut Pbm Exception DBMS_UTILITY.comma_to_table
    Dans une fonction qui est imbriquée dans une procédure, j'utilise
    DBMS_UTILITY.comma_to_table pour séparer des données saisies pas l'utilisateur.
    Je dois donc prévoir les excéptions sur cette commande.
    J'ai essayé avec :
    EXCEPTION
    WHEN OTHERS
    THEN
    affiche_msg ('erreur de saisie')

    ma fonction affiche_msg() affichant une page html avec un lien javascript permettant à l'utilisateur de revenir à la page précédente.
    Mon problème est qu'après avoir lever l'excéption, mon programme continue et que juste derrière j'ai un COMMIT. je voudrais qu'il ne continue pas sur le COMMIT.
    Avez vous une idée pour gérer les exceptions et que mon programme ne continue pas ?

    Merci

  2. #2
    Membre Expert Avatar de Garuda
    Homme Profil pro
    Chef de projet / Urbaniste SI
    Inscrit en
    Juin 2007
    Messages
    1 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet / Urbaniste SI
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 285
    Par défaut
    Une solution est de renvoyer une erreur specifique au traitement et de l'ignorer dans la gestion des exceptions (technique dite de propagation)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
     
    /* Formatted on 2007/08/08 15:41 (Formatter Plus v4.8.8) */
    DECLARE
       -- on cree une exception specifique
       erreur_saisie EXCEPTION ;
    BEGIN
       -- ici du traitement
     
      .......
       -- on isole l'alimentation de la table
       BEGIN
          DBMS_UTILITY.comma_to_table...
       EXCEPTION
          -- on genere l'erreur specifique
          WHEN OTHERS
          THEN
             RAISE erreur_saisie;
       END;
       -- ici encore du traitement
       -- qu'on saute en cas de erreur_saisie
       ....
       COMMIT;
    EXCEPTION
       -- si on est la, c'est que l'alimentation n'a pas marché
       WHEN erreur_saisie
       THEN
          affiche_msg('erreur !');
       -- sinon, ontraite les autres erreurs
       WHEN OTHERS THEN
          ROLLBACK;
    END;

  3. #3
    Membre Expert Avatar de Garuda
    Homme Profil pro
    Chef de projet / Urbaniste SI
    Inscrit en
    Juin 2007
    Messages
    1 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet / Urbaniste SI
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 285
    Par défaut
    Une question me tarabuste

    Est-ce du PL/SQL pur (coté serveur) ?
    Si oui, comment fais-tu pour afficher une page HTML ?
    Si non, c'est du forms ?

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 16
    Par défaut
    Citation Envoyé par Garuda
    Une question me tarabuste

    Est-ce du PL/SQL pur (coté serveur) ?
    Si oui, comment fais-tu pour afficher une page HTML ?
    Si non, c'est du forms ?
    Merci bcp Garuda.
    pour ta question dans mon exception j'appelle une procédure handle(SQLCODE) qui suivant le code retourné va appeler une procédure d'affichage de message affiche_msg (msg) qui elle va faire des HTP.p().

  5. #5
    Membre Expert Avatar de Garuda
    Homme Profil pro
    Chef de projet / Urbaniste SI
    Inscrit en
    Juin 2007
    Messages
    1 285
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chef de projet / Urbaniste SI
    Secteur : Bâtiment

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 285
    Par défaut
    Bon, j'ai pas tout compris mais j'espère que tu as ton pb !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. PBM : TADOQuery et TRY..EXCEPT ?
    Par fredfred dans le forum Bases de données
    Réponses: 5
    Dernier message: 25/07/2006, 16h58
  2. [Crystal Report 8.5 + VB6] Pbm déploiment
    Par La Gillasse dans le forum SDK
    Réponses: 2
    Dernier message: 14/10/2002, 15h19
  3. Pbm avec les '&'...
    Par AmaX dans le forum Composants VCL
    Réponses: 2
    Dernier message: 19/08/2002, 11h08
  4. Réponses: 5
    Dernier message: 12/06/2002, 15h12
  5. c: gestion des exceptions
    Par vince_lille dans le forum C
    Réponses: 7
    Dernier message: 05/06/2002, 14h11

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo