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

ADO.NET Discussion :

Manipulation d'un DataReader!


Sujet :

ADO.NET

  1. #1
    Membre régulier
    Inscrit en
    Novembre 2010
    Messages
    163
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 163
    Points : 77
    Points
    77
    Par défaut Manipulation d'un DataReader!
    Bonjour à tous

    J'utilise dans mon code C# les DataReader (fournisseur OracleDataReader). Je veux effectuer un test sur ce Reader pour savoir si la requête retourne quelque chose ou non! Mais sans réussite Voici le code que j'utilise:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     
                        OracleCommand comm60 = new OracleCommand("select max(C_GRP) from groupe_image where C_GRP like '%GE%'", connexion);
                        OracleDataReader reader60 = comm60.ExecuteReader();
                        reader60.Read();
     
                        if (reader60.Read())
                        {
                            decimal indice2 = Convert.ToDecimal(reader60.GetString(0).Substring(2, Convert.ToInt16(reader60.GetString(0).Length) - 2));
                            CODE_GE2 = "GE" + Convert.ToString(indice2 + 1);
                        }
    En fait, je veux si la requête précédente retourne une valeur, j'effectue cette instruction. Est ce que ce code est juste?

    Merci pour votre coopération

  2. #2
    Membre expérimenté Avatar de bizet
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2005
    Messages
    717
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2005
    Messages : 717
    Points : 1 338
    Points
    1 338
    Par défaut
    Salut

    permet de connaitre le nombre de lignes retournées par la requete.

  3. #3
    Membre régulier
    Inscrit en
    Novembre 2010
    Messages
    163
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 163
    Points : 77
    Points
    77
    Par défaut
    Mais je pense que la propriété HasRows est de type bool, nn?

  4. #4
    Membre régulier
    Inscrit en
    Novembre 2010
    Messages
    163
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 163
    Points : 77
    Points
    77
    Par défaut
    Je crois que la meilleure solution est d'utiliser un count(*), ceci m'a aidé à résoudre mon problème. Voici le code que j'ai implémenté:


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     
    OracleCommand nbr_ge = new OracleCommand("select count(*) from groupe_image where C_GRP like '%GE%'",connexion);
    decimal nbr = (decimal)nbr_ge.ExecuteScalar();
    Comme ça je retourne le nombre de ligne de la requête!

    Une façon pour contourner le problème car la propriété HasRows n'a rien donné

    Merci pour ton aide

  5. #5
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    Votre but est de savoir si vous avez au moins un ligne pas d'en connaitre le nombre non?
    La commande hasrows suffit donc...

    En outre préférez le EXISTS en dans vos requêtes plutôt que le COUNT....
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

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

Discussions similaires

  1. Manipulation des handle contexte
    Par rockbiker dans le forum DirectX
    Réponses: 1
    Dernier message: 09/05/2003, 18h51
  2. Manipuler JAVA et SSL ?
    Par jah dans le forum Sécurité
    Réponses: 6
    Dernier message: 05/05/2003, 00h30
  3. [VB6]manipuler les semaines en VB ?
    Par kamadji dans le forum VB 6 et antérieur
    Réponses: 7
    Dernier message: 02/05/2003, 12h33
  4. Réponses: 2
    Dernier message: 18/01/2003, 17h06
  5. Fonctions de manipulation des chaines et des dates
    Par Fares BELHAOUAS dans le forum Débuter
    Réponses: 3
    Dernier message: 09/11/2002, 22h43

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