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 :

Récupérer un paramètre output d'une procédure stockée


Sujet :

C#

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    207
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 207
    Points : 191
    Points
    191
    Par défaut Récupérer un paramètre output d'une procédure stockée
    Bonjour dans le cadre de mon projet de session je dois récupérer une valeur d'une procédure stocké. Jusque la ma procédure et fonctionnelle et elle me retourne bien la valeur que je désire. Par contre lorsque j'arrive dans mon application je ne réussi pas à récupérer cette valeur. Je me doute que le problème ne sois pas grand chose, mais je cherche depuis quelques temps pour trouver la solution et rien encore.

    Voici le code que j'utilise pour tenter de récupérer cette valeur

    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
     
        public string calculer_joueur_disc(string unite, string sport)
        {
            string connectionString = "xxxxxxxx";
            SqlConnection connection = new SqlConnection(connectionString);
            SqlDataReader reader = null;
            string lsligne = "0";
            try
            {
                string commandText = "nbreJoueur";
                SqlCommand command = new SqlCommand(commandText, connection);
                command.CommandType = CommandType.StoredProcedure;
                command.Parameters.AddWithValue("@UNITEID", unite);
                command.Parameters.AddWithValue("@SPORTID", sport);
                SqlParameter ligne = new SqlParameter("@LIGNE", SqlDbType.Int);
                ligne.Direction = ParameterDirection.Output;
                command.Parameters.Add(ligne);
                connection.Open();
                lsligne = ligne.Value.ToString();
                return lsligne;
            }
            catch (Exception ex)
            {
                return "-1";
            }
            finally
            {
                connection.Close();
            }
        }

  2. #2
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Réunion

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 277
    Points : 1 521
    Points
    1 521
    Par défaut
    Il manque le code qui exécute la requête après le connection.Open() ça risque donc pas de fonctionner.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    reader = command.ExecuteReader();

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    207
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 207
    Points : 191
    Points
    191
    Par défaut
    Merci de ta réponse. Par contre lorsque j'active le reader je reçois un message d'erreur du genre:

    Error converting data type nvarchar to numeric.

    Et je n'ai aucune idée d'où cela peu provenir.

  4. #4
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Réunion

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 277
    Points : 1 521
    Points
    1 521
    Par défaut
    A mon avis, ta procédure stockée ne retourne pas le bon type de résultat.

  5. #5
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Points : 6 334
    Points
    6 334
    Par défaut
    Pourquoi ne pas faire simplement un executescalar voire executeNonQuery Etant donné que la valeur de retour est définie dans un paramètre de sortie, tu n'as finalement aucune donnée à lire dans un Reader, si ?

Discussions similaires

  1. [XL-2010] Pas de retour sur un paramètre output depuis une procédure stockée oracle
    Par darmet dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 28/07/2014, 14h47
  2. Réponses: 6
    Dernier message: 15/09/2010, 18h02
  3. Réponses: 1
    Dernier message: 27/08/2007, 17h40
  4. récupérer le code source d'une procédure stockée
    Par mike00 dans le forum VB 6 et antérieur
    Réponses: 21
    Dernier message: 13/06/2007, 11h31
  5. Réponses: 3
    Dernier message: 04/05/2007, 14h03

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