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

ASP.NET Discussion :

Requete vide ?


Sujet :

ASP.NET

  1. #1
    Membre actif
    Homme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 220
    Points : 268
    Points
    268
    Par défaut Requete vide ?
    Bonjour,

    Je fais une requete qui me séléctionne un MAX et qui me retourne une valeur, seulement je ne parviens pas à récupérer cette valeur, j'ai à chaque fois une erreur me disant que la valeur est nulle...

    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
    public int PourcentageQtte(float QtteStock)
            {
                float QtteMax;
                DbDataReader DbReader;
     
                SqlConnection sqlconn = new SqlConnection();
                sqlconn.ConnectionString = ConfigurationManager.ConnectionStrings["prodchimiquesConnectionString"].ConnectionString;
                sqlconn.Open();
     
                SqlCommand SqlComm = sqlconn.CreateCommand();
     
                SqlComm.CommandText = @"SELECT MAX(Quantite_Utilisee) AS 'QMAX' FROM Article";
     
                DbReader = SqlComm.ExecuteReader();
     
                QtteMax = float.Parse(DbReader["QMAX"].ToString());
    L'erreur est la suivante:
    Tentative non valide de lecture lorsque aucune donnée n'est présente.

    Edit: la requete dans SqlServer me renvoie bien mon résultat

  2. #2
    Modérateur

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Avril 2007
    Messages
    1 996
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 996
    Points : 3 102
    Points
    3 102
    Par défaut
    Dans la mesure où tu fais un Select Max(), le dataReader est inutile.
    Celui-ci sert à récupérer une liste de résultats.
    Dans le cas précis un ExecuteScalar serait plus adapté selon moi.

    Enfin, il te faut parcourir ton reader pour en récupérer les valeurs :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    while (DbReader.Read()){ QtteMax = float.Parse(DbReader["QMAX"].ToString());
     }

  3. #3
    Membre actif
    Homme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 220
    Points : 268
    Points
    268
    Par défaut
    J'ai utilisé le ExecuteScalar pour pas faire trop lourd, en effet ça fonctionne bien! Merci!!

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

Discussions similaires

  1. Tester si requete vide
    Par koyot3 dans le forum VBA Access
    Réponses: 12
    Dernier message: 08/07/2014, 11h04
  2. Retourne un enreg si requete vide
    Par calou_33 dans le forum SQL
    Réponses: 0
    Dernier message: 04/11/2008, 17h48
  3. GridView ne s'affiche pas si requete vide
    Par Syrrus dans le forum ASP.NET
    Réponses: 6
    Dernier message: 07/02/2008, 10h02
  4. Réponses: 1
    Dernier message: 13/01/2008, 21h02
  5. Resultats de requetes vides et pourtant !!
    Par ahage4x4 dans le forum ASP
    Réponses: 2
    Dernier message: 19/05/2005, 15h30

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