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

C# Discussion :

Appel de procédure stockée


Sujet :

C#

  1. #1
    Membre régulier
    Inscrit en
    Juillet 2007
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 113
    Points : 76
    Points
    76
    Par défaut Appel de procédure stockée
    Bonjour tout le monde,

    Voici mon soucis du jour :

    J'appelle une procédure stockée via C#.

    Je fais donc :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    commande.CommandType = CommandType.StoredProcedure;
    commande.ExecuteNonQuery();
    Tout fonctionne bien. Par contre, je souhaite récupérer le nombre de lignes concernées par les UPDATE/INSERT de ma proc stock.

    ExecuteNonQuery() ne me retourne que -1... Tout le temps.

    Est ce que je dois modifier ma procédure sotckée ou modifier mon appel ?

    Merci d'avance de votre aide.

    Cordialement

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    Apparemment c'est normal...

    http://msdn.microsoft.com/fr-fr/libr...enonquery.aspx
    Citation Envoyé par MSDN
    Pour les instructions UPDATE, INSERT et DELETE, les valeurs de retour représentent le nombre de lignes affectées par la commande. Lorsqu'un déclencheur existe sur une table qui est insérée ou mise à jour, la valeur de retour inclut à la fois le nombre de lignes affectées par l'opération d'insertion ou de mise à jour et le nombre de lignes affectées par le ou les déclencheurs. Pour tous les autres types d'instructions, la valeur de retour est -1. En cas d'annulation, la valeur de retour est la même -1.
    Ce que tu pourrais faire, c'est modifié ta procédure stockée de façon à ce qu'elle renvoie le nombre de lignes affectées, et l'appeler avec ExecuteScalar au lieu de ExecuteNonQuery. Ou alors (plus propre je pense), ajouter à la procédure stockée un paramètre de sortie, qui contiendra après l'appel le nombre de lignes affectées.

  3. #3
    Membre régulier
    Inscrit en
    Juillet 2007
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 113
    Points : 76
    Points
    76
    Par défaut
    Bonjour Tomlev,

    Je prends la deuxième option :

    ajouter à la procédure stockée un paramètre de sortie, qui contiendra après l'appel le nombre de lignes affectées.
    Merci de ton aide

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 07/02/2006, 00h11
  2. Réponses: 3
    Dernier message: 17/01/2006, 17h12
  3. Update appelant une procédure stockées
    Par meufeu dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 06/10/2005, 18h31
  4. [appeler une procédure stockée]
    Par viny dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 10/03/2005, 22h38
  5. Appel de Procédure stockée en ASP
    Par James85 dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 14/11/2004, 17h55

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