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

Accès aux données Discussion :

[C#/SQL] Comment gérer les exceptions d'une Procédure stockée ?


Sujet :

Accès aux données

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    137
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 137
    Points : 143
    Points
    143
    Par défaut [C#/SQL] Comment gérer les exceptions d'une Procédure stockée ?
    Bonjour.

    Dans mon code écrit en C#, je dois à un moment donné faire appel à une procédure stockée sur une base SQL Server pour mettre à jour la base de données.

    Ce que je voudrais savoir, c'est quelle est la meilleure méthode pour savoir si la procédure s'est bien déroulée.

    Avec un paramètre de type OUTPUT ?
    Avec la valeur retournée par la procédure ? ( je voudrais éviter ce cas, certaines procédures me renvoyant des résultats via des SELECT, je ne vois pas trop comment récupérer alors cette valeur )

    Peutetre y a-t-il une autre manière de procéder ?

    Merci d'avance.

  2. #2
    Expert éminent
    Avatar de neguib
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 627
    Détails du profil
    Informations personnelles :
    Âge : 63
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 627
    Points : 7 879
    Points
    7 879
    Par défaut
    celà me parit difficile de creer un modèle unique quelquesoit le type de procedure
    je crois qu'au minimum tu dois distinguer les Select des autres
    celà ne te fera que 2 types de valeurs retour à gérer
    1. les valeurs du select
    2. le nombre de lignes affectées
    Pour le bien de ceux qui vous lisent, ayez à coeur le respect du forum et de ses règles

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    137
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 137
    Points : 143
    Points
    143
    Par défaut
    J'ai également vu que sous Transact-SQL ( le SQL de chez SQL Server ), on pouvait lever des exceptions via la commande :
    RAISERROR

    Est-ce qu'il y a un moyen de la récupérer du côté de chez C# ?

  4. #4
    Expert éminent
    Avatar de neguib
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 627
    Détails du profil
    Informations personnelles :
    Âge : 63
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 627
    Points : 7 879
    Points
    7 879
    Par défaut
    il me semble que la classe sqlException est là pour cela non
    Pour le bien de ceux qui vous lisent, ayez à coeur le respect du forum et de ses règles

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    137
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 137
    Points : 143
    Points
    143
    Par défaut
    Comment ca marche alors ? Comme ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    try
    {
    fonction_executant_la_procedure();
    }
    catch(sqlException exception )
    {
    }
    ?

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    137
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 137
    Points : 143
    Points
    143
    Par défaut
    Parce que pour les requêtes simples, je suis d'accord avec le traitement de ces SqlException, mais dans le cas de procédures stockées ?

  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    137
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 137
    Points : 143
    Points
    143
    Par défaut
    Ok, c'est bon, je viens de voir un article dessus sur le Net, ça a l'air de marcher.

    Merci pour ton aide.

  8. #8
    Expert éminent
    Avatar de neguib
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 627
    Détails du profil
    Informations personnelles :
    Âge : 63
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 627
    Points : 7 879
    Points
    7 879
    Par défaut
    A ma connaissance
    3 classes sont en lien avec les erreurs générées par sqlserver
    - Classe SqlErrorCollection
    -Classe SqlError
    - Classe SqlException
    Mais seule la dernière va lever une exception
    Pour le bien de ceux qui vous lisent, ayez à coeur le respect du forum et de ses règles

  9. #9
    Rédacteur
    Avatar de Louis-Guillaume Morand
    Homme Profil pro
    Cloud Architect
    Inscrit en
    Mars 2003
    Messages
    10 839
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Cloud Architect
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2003
    Messages : 10 839
    Points : 28 252
    Points
    28 252
    Par défaut
    Citation Envoyé par thomas_strass
    Ok, c'est bon, je viens de voir un article dessus sur le Net, ça a l'air de marcher.

    Merci pour ton aide.
    url, url
    je suis en plein dedans et ce cas m'intéresse car j'en aurais eventuellement besoin

    merci
    moi c'est Louis-Guillaume, ni Louis, ni Guillaume mais Louis-Guillaume et je n'aide pas ceux qui écorchent mon nom

  10. #10
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    137
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 137
    Points : 143
    Points
    143
    Par défaut
    En fait, je suis allé voir plusieurs sites. Alors pour les retrouver
    Je suis déjà allé voir le site de Microsoft,
    http://msdn.microsoft.com/library/de...ClassTopic.asp

    ils y expliquent que la SQLException comporte le "severity level", donc ca m'a l'air tout bon ...

    J'essaierais demain dans mon code pour voir si je la récupère effectivement.

    De toutes manières, je pense que je vais plutot m'orienter vers la valeur retournée par la procédure stockée, c'est plus simple et, je pense, plus rapide :

    http://msdn.microsoft.com/library/de...parameters.asp
    Partie "To get a procedure's return value"

  11. #11
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    137
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Juillet 2002
    Messages : 137
    Points : 143
    Points
    143
    Par défaut
    Je viens d'essayer le code avec le raiserror, ca marche bien, je récupère effectivement une System.Data.SqlClient.SqlException, donc c'est cool

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

Discussions similaires

  1. Comment gérer les exceptions sur un tdbgrid?
    Par zanoubya dans le forum Débuter
    Réponses: 5
    Dernier message: 21/12/2011, 15h14
  2. Comment gérer les exceptions des DetailsView ?
    Par insane_80 dans le forum ASP.NET
    Réponses: 1
    Dernier message: 21/01/2011, 15h39
  3. Réponses: 3
    Dernier message: 29/05/2007, 16h50
  4. [VB] - Comment gérer les tabulations sur une fiche ?
    Par guiguikawa dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 06/03/2007, 13h28
  5. [Sql] Comment lister les tables d'une base ?
    Par Mynautor dans le forum DB2
    Réponses: 6
    Dernier message: 05/09/2005, 13h21

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