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 :

recupérer le resultat d'une requête sql


Sujet :

ASP.NET

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 97
    Par défaut recupérer le resultat d'une requête sql
    Bonsoir,

    je cherche un moyen simple de récupérer les résultats d'une requête sql.

    Pour être plus clair, j'ai une requete SQL qui me retourne une seule et unique ligne contenant 5 champs.
    J'ai besoin des valeurs de ces 5 champs pour la suite du traitement donc j'aimerai pouvoir les stocker dans une variable afin de pouvoir les utiliser ultérieurement.

    Il existe la solution du dataset, mais n'existe-t'il pas de méthode plus "simple" comme cela peut-être le cas avec une requete qui ne retourne qu'un seul champ?

    D'avance merci,
    Tommy

  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
    Par défaut
    Citation Envoyé par Tommy57 Voir le message
    Il existe la solution du dataset, mais n'existe-t'il pas de méthode plus "simple" comme cela peut-être le cas avec une requete qui ne retourne qu'un seul champ?
    Le DataSet pour une ligne, ce n'est pas très adéquat...

    Utilise la méthode DbCommand.ExecuteReader, comme si tu avais plusieurs lignes.

    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
    string a;
    int b;
    double c;
    DateTime d;
    decimal e;
     
    using (DbCommand command = connection.CreateCommand())
    {
        command.CommandText = "SELECT A, B, C, D, E FROM ... WHERE ...";
        using (DbDataReader reader = command.ExecuteReader())
        {
            if (reader.Read())
            {
                a = reader.GetString(0);
                b = reader.GetInt32(1);
                c = reader.GetDouble(2);
                d = reader.GetDateTime(3);
                e = reader.GetDecimal(4);
            }
        }
    }

  3. #3
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2008
    Messages
    337
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Septembre 2008
    Messages : 337
    Par défaut
    Pour les requêtes qui retournent qu'une seul valeur tu peux utiliser la méthode SqlCommand.ExecuteScalar.

Discussions similaires

  1. Réponses: 2
    Dernier message: 12/06/2011, 00h00
  2. [Smarty] boucle pour afficher le resultat d'une requête SQL
    Par emi226 dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 15/08/2010, 21h58
  3. Réponses: 6
    Dernier message: 25/09/2009, 13h28
  4. Resultat d'une requête SQL sous C
    Par riadh8 dans le forum Linux
    Réponses: 1
    Dernier message: 18/04/2009, 21h47
  5. Réponses: 1
    Dernier message: 07/04/2008, 11h23

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