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

MS SQL Server Discussion :

Gestion d'erreur dans les procédure


Sujet :

MS SQL Server

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mars 2003
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Mars 2003
    Messages : 39
    Points : 37
    Points
    37
    Par défaut Gestion d'erreur dans les procédure
    Bonjour,

    Je cherche à savoir comment gérer les erreur sur SQL Serveur,
    La plupart des exemples que j'ai trouvé ne fonctionnent pas:

    http://www.developpez.net/forums/vie...reur+procedure

    Je voudrais gérer le cas suivant:
    Dans la base PUBS donnée en exemple avec SQL Serveur,


    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
     
     
    CREATE  PROCEDURE dbo.testerreur 
    AS
    begin 
    insert into authors(city) values(20) 
    if @@error <> 0 
       begin 
       raiserror 20001 "Erreur lors de l'insertion" 
       return -1 
       end 
    else 
       return 0 
    end
     
     
     
    GO
    Ici l'insert provoque une erreure d'insertion. Cette erreur arréte la procédure et ne passe pas dans le code de gestion d'erreur.

    Existe-t-il une solution pour gérer ces erreur?

  2. #2
    BiM
    BiM est déconnecté
    Expert éminent sénior
    Avatar de BiM
    Femme Profil pro
    Consultante/Formatrice BIRT & Ingénieur Java/J2EE/GWT
    Inscrit en
    Janvier 2005
    Messages
    7 796
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultante/Formatrice BIRT & Ingénieur Java/J2EE/GWT

    Informations forums :
    Inscription : Janvier 2005
    Messages : 7 796
    Points : 10 765
    Points
    10 765
    Par défaut
    Quelle est cette erreur exactement ?

  3. #3
    Nouveau membre du Club
    Inscrit en
    Mars 2003
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Mars 2003
    Messages : 39
    Points : 37
    Points
    37
    Par défaut
    ici c'est une procedure que j'ai créé pour tester la gestion d'erreur.

    L'insert dans la procédure provoque un erreur d'insertion car il y a un certain nombre de champs qui ont une contrainte not null.

    je voulait donc provoquer une erreur avec l'instruction insert pour vérifier que la procédure continue et me permette de tester @@error et gérer proprement l'erreur.

    Malheureusement, l'erreur provoquée par l'insert arréte la procédure stoquée juste aprés l'insert.

    Chose que j'ai du mal à conprendre car l'exemple donné dans la documentation SQL Server est quasiment le meme.

  4. #4
    Rédacteur
    Avatar de WOLO Laurent
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Mars 2003
    Messages
    2 741
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Congo-Brazzaville

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 2 741
    Points : 4 414
    Points
    4 414
    Par défaut Re: Gestion d'erreur dans les procédure
    Il faut ajouter simplement Set NoCount ON et Set NoCount OFF

    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
    CREATE  PROCEDURE dbo.testerreur 
    AS
    Set NoCount ON
    begin 
    insert into authors(city) values(20) 
    if @@error <> 0 
       begin 
       raiserror 20001 "Erreur lors de l'insertion" 
       return -1 
       end 
    else 
       return 0 
    end
    Set NoCount OFF
    GO

    Découvrez la FAQ de MS SQL Server.
    La chance accorde ses faveurs aux esprits avertis !

  5. #5
    Nouveau membre du Club
    Inscrit en
    Mars 2003
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Mars 2003
    Messages : 39
    Points : 37
    Points
    37
    Par défaut
    Excellent, c'est exactement ce que je cherchait, je te remercie.

    ps: par défaut, il est à off?

  6. #6
    Opo
    Opo est déconnecté
    Nouveau membre du Club
    Inscrit en
    Juillet 2002
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 35
    Points : 36
    Points
    36
    Par défaut
    Bonjour,

    Je me sers du code fourni pour tester une gestion d'erreur ... j'ai une erreur à la compilation de la procédure car la valeur insérée ds la table est incorrecte.
    Donc je ne peux même pas voir si la gestion d'erreur répond à mon besoin.
    Comment faire ?
    D'avance merci de vos réponses

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

Discussions similaires

  1. [AC-2010] Gestion d'erreur dans les modules
    Par Caramel13 dans le forum VBA Access
    Réponses: 1
    Dernier message: 11/01/2014, 00h44
  2. [AC-2003] Gestion des erreurs dans les sous-programmes
    Par azertix dans le forum VBA Access
    Réponses: 2
    Dernier message: 26/10/2010, 11h13
  3. Réponses: 0
    Dernier message: 07/04/2010, 16h39
  4. Gestion d'erreur dans une procédure
    Par willytito dans le forum VBA Access
    Réponses: 5
    Dernier message: 08/08/2008, 14h04
  5. Gestion des erreurs dans les pages JSP
    Par elewandowski dans le forum Struts 2
    Réponses: 3
    Dernier message: 04/12/2007, 21h18

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