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 :

DBMS_OUTPUT : récupération des erreurs


Sujet :

SQL Oracle

  1. #1
    Membre éclairé
    Homme Profil pro
    Développeur
    Inscrit en
    Juin 2006
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Juin 2006
    Messages : 645
    Points : 709
    Points
    709
    Par défaut DBMS_OUTPUT : récupération des erreurs
    Bonjour,

    je pense queje vais poser une question bête, mais je suis incapable d'en trouver la réponse (peut-être tout simplement parce que je n'utilise pas les bons mots clefs).

    Je suis en train de développer une application qui génère des scripts SQL (stockés ensuite sous forme de fichiers textes). Ces scripts sont exécutés à une date donnée et on souhaite récupérer les résultats (pour savoir quelle requête est passée, laquelle n'a pas fonctionnée, etc).

    En cas d'erreur, je dois ressortir :
    - le code d'erreur ;
    - le message d'erreur.

    On m'impose l'utilisation de dbms_output (spool et utl_file sont rigoureusement interdits).

    Pour le moment, j'ai quelque chose comme ceci, mais il me manque la récupération des messages d'erreur éventuels. De quel côté faut-il que je regarde pour faire ça ?
    Code SQL : 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
    -- Ouverture du tampon --
    DBMS_OUTPUT.ENABLE( 1000000 ) ;
     
    -- Requete 1 --
    DBMS_OUTPUT.PUT_LINE('Description de ma requete') ;
    DELETE ma_table WHERE aaa = 'bbb';
    DBMS_OUTPUT.NEW_LINE ;    
     
    -- Requete 2 --
    DBMS_OUTPUT.PUT_LINE('Description de ma requete') ;
    UPDATE ....
    DBMS_OUTPUT.NEW_LINE ;  
     
    -- Requete 3 --
    DBMS_OUTPUT.PUT_LINE('Description de ma requete') ;
    INSERT ....
    DBMS_OUTPUT.NEW_LINE ;
    Merci d'avance !

    Alban

  2. #2
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    EXCEPTION
      WHEN OTHERS THEN
        dbms_output.put_line(SQLERRM);
    END;

  3. #3
    Membre averti Avatar de LBO72
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    406
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 406
    Points : 342
    Points
    342
    Par défaut
    Et pour le code erreur, utilise le SqlCode

    EXCEPTION
    WHEN OTHERS THEN
    dbms_output.put_line(SQLCODE || SQLERRM);
    END;

    LBO72

  4. #4
    Membre éclairé
    Homme Profil pro
    Développeur
    Inscrit en
    Juin 2006
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Juin 2006
    Messages : 645
    Points : 709
    Points
    709
    Par défaut
    Merci ! C'est vraiment le genre de choses que je n'avais jamais vu (* honte *)...


    Donc je place ça juste après ma requête et ça fonctionne ?

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    INSERT INTO ma_table ('champ1','champ2') VALUES ('aa','bb');
    EXCEPTION
      WHEN OTHERS THEN
         dbms_output.put_line(SQLCODE  ||  SQLERRM);
      END;

  5. #5
    Membre averti Avatar de LBO72
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    406
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 406
    Points : 342
    Points
    342
    Par défaut
    Tu fais cela en fin de ton script sql, et ça sera valable pour toutes tes requêtes.

    LBO72.

  6. #6
    Membre éclairé
    Homme Profil pro
    Développeur
    Inscrit en
    Juin 2006
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Juin 2006
    Messages : 645
    Points : 709
    Points
    709
    Par défaut
    Ok. Merci

    Et juste pour être un peu tâtillon et essayer de comprendre un peu plus, si je veux gérer indépendamment les erreurs, je fais quelque chose comme ça ? (je le cite, parce que sens très fortement que ça ne va pas justement...)


    Code SQL : 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
    whenever sqlerror exit 1 rollback
    whenever oserreor exit 1 rollback 
     
    BEGIN 
    dbms_output.put_line('Ma requete 1');
    INSERT INTO ma_table ('champ1','champ2') VALUES ('aa','bb');
    EXCEPTION
      WHEN OTHERS THEN
         dbms_output.put_line(SQLCODE  ||  SQLERRM);
      END;
     
    BEGIN
    dbms_output.put_line('Ma requete 2');
    DELETE ma_table WHERE champ1 = 'aa';
    EXCEPTION
      WHEN OTHERS THEN
         dbms_output.put_line(SQLCODE  ||  SQLERRM);
      END;
     
    commit;
    exit

  7. #7
    Membre averti Avatar de LBO72
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    406
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 406
    Points : 342
    Points
    342
    Par défaut
    Ce que tu as fait pour spécialiser le message pour chaque requête marchera(presque). Il faut juste ajouter tout de même un bloc exception globale à la fin de ton script.
    Pour ne pas sortir deux fois chaque requête, l'exception globale de ton script doit être sous la forme :

    Exception
    When others then
    je ne fais rien .... pour ne pas ré-afficher la requête
    end

  8. #8
    Membre éclairé
    Homme Profil pro
    Développeur
    Inscrit en
    Juin 2006
    Messages
    645
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Juin 2006
    Messages : 645
    Points : 709
    Points
    709
    Par défaut
    En d'autres termes :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    WHEN OTHERS THEN
    END;


    En tout cas, merci : ça m'enlève une épine du pied !

  9. #9
    Membre averti Avatar de LBO72
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    406
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 406
    Points : 342
    Points
    342
    Par défaut
    C'est tout à fait ça...

    Et je suis content d'avoir contribué à t'aider à enlève l'épine de ton pied

    LBO72

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

Discussions similaires

  1. Récupération des erreurs d'une appli console win32
    Par Gouyon dans le forum Visual C++
    Réponses: 8
    Dernier message: 28/11/2014, 09h53
  2. Récupération des erreurs sur la commande systeme nslookup
    Par loiki dans le forum Programmation et administration système
    Réponses: 1
    Dernier message: 03/05/2011, 11h36
  3. [EJB] [Corba] Récupération des erreurs COMM_FAILURE
    Par piopium dans le forum Java EE
    Réponses: 0
    Dernier message: 08/03/2009, 13h24
  4. Probleme récupération des erreurs
    Par BILLANT dans le forum VBScript
    Réponses: 0
    Dernier message: 28/01/2009, 18h15
  5. Récupération des erreurs sur SQL Express 2005
    Par luddo91 dans le forum MS SQL Server
    Réponses: 12
    Dernier message: 18/06/2008, 22h59

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