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 :

Utilisation de multiples SqlDataReader


Sujet :

C#

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2009
    Messages : 28
    Points : 23
    Points
    23
    Par défaut Utilisation de multiples SqlDataReader
    Bonjour,
    J'ai un problème avec l'utilisation deux SQLDataReader, car au deuxième ExecuteReader(), j'ai cette erreur :
    «System.InvalidOperationException: Un DataReader associé à cette commande est déjà ouvert. Il doit d'abord être fermé.».
    J'ai pu voir que c'est parce qu'on ne peut utiliser deux reader en même temps, mais dans ma situation, je ne peux fermer mon reader principal.

    Voici mon code :
    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
    private void CreateTableau()
    {
      TableCell CelluleDonneeProduit;
      TableRow RowDonneeProduit;
     
      myConn.Open(); 
      SqlCommand cmd = myConn.CreateCommand();
      cmd.CommandText = "SELECT DISTINCT aa, bb, cc, dd, ee, ff FROM tabcd";
      SqlDataReader reader = cmd.ExecuteReader();
     
      while (reader.Read())
      {
        for (int j = 0; j <= 5; j++)
        {
          CelluleDonneeProduit = new TableCell();
          else if (j == 2)
          {
            TexteInfoBulle = reader.GetString(5) + "<br />" + 
            AfficheCommentaire(reader.GetString(1));
            ...
          }
          RowDonneeProduit.Cells.Add(CelluleDonneeProduit);
          Row.CssClass = CssClass;
          tableau.Rows.Add(Row);
      }
      myConn.Close();
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    private string AfficheCommentaire(string CodeItem)
    {
        string Texte = "";
        SqlCommand cmd = myConn.CreateCommand();
        SqlDataReader reader;
        cmd.CommandText = "SELECT DISTINCT Comm FROM tcomm WHERE GG=CodeItem";
        reader = cmd.ExecuteReader();
     
        while (reader.Read())
        {
            Texte += "<br />" + reader.GetString(0);
        }
        return Texte;
    }
    AfficheCommentaire retourne 0 ou plusieurs commentaires que l'on concatène pour ensuite envoyer le résultat dans le tableau.

    Je voudrais savoir s'il y a un moyen d'exécuter ces deux reader sans fermer la première, car il doit continuer à peupler le tableau.

  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 : 42
    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

Discussions similaires

  1. Réponses: 4
    Dernier message: 23/06/2014, 08h58
  2. Utiliser Allow Multiple Values dans l'API
    Par donino dans le forum BIRT
    Réponses: 2
    Dernier message: 09/08/2011, 21h25
  3. [SBI BIRT] Erreur de transformation quand Birt utilise Allow Multiples values
    Par atee dans le forum SpagoBI
    Réponses: 1
    Dernier message: 23/04/2009, 17h09
  4. Utilisation dataSource multiples
    Par Jean Luc BOUGEARD dans le forum Hibernate
    Réponses: 5
    Dernier message: 23/01/2007, 17h47
  5. utilisation de multiple h:selectOneMenu
    Par *alexandre* dans le forum JSF
    Réponses: 1
    Dernier message: 27/07/2006, 15h01

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