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 :

[MYSQL]VS 2005 DataReader already open


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5
    Par défaut [MYSQL]VS 2005 DataReader already open
    Bonjour,
    Je suis sur VB2005 C# avec MySQL5.0 et le connecteur MySql net 5.1.4 (dernier)

    Mon but est simplement pendant que je parcours la lecture d'une table en lire une autre sans devoir faire une jointure dans ma commande sql.
    Je peux aussi ouvrir un deuxième connecteur à ma base de donnée, mais perte de performance lors de l'ouverture d'un deuxième connecteur.

    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
     
                string connStr = "server=xxx;user id=xxx; password=xxx; database=xxxx; pooling=true;";
                conn = new MySqlConnection(connStr);
                conn.Open();
                // --------------------------
                MySqlDataReader reader = null;
                MySqlCommand cmd = new MySqlCommand("SELECT REF FROM CAT_OFFRE WHERE SUPPLIER = 'APPLE'", conn);
                reader = cmd.ExecuteReader();
                while (reader.Read())
                {
                        MySqlDataReader reader2 = null;
                        MySqlCommand cmd2 = new MySqlCommand("SELECT REF FROM CAT_OFFRE WHERE SUPPLIER = 'APPLE'", conn);
                        reader2 = cmd2.ExecuteReader();
                        while (reader2.Read())
                        {
                            Response.Write(reader2["REF"].ToString().Trim() + "<br />");
                        }
                        reader2.Close();
                        cmd2.Dispose();
                }
                reader.Close();
                cmd.Dispose();
                // --------------------------
                conn.Close();
                conn.Dispose();
    Mon message d'erreur : There is already an open DataReader associated with this Connection which must be closed first.
    Dans la boucle lors de la lecture de la ligne : reader2 = cmd2.ExecuteReader();
    Je sais j'ai deux fois la même requetes. tests.
    J'ai trouvé cette explication : "But there is a flag in MS SQL connection string which allows multiple readers to be open for a single connection: "MultipleActiveResultSets=True" solves the problem. "
    J'ai essayé de le placer dans la connectionstring mais commande inconnue.

    Pour info, quand je fais la même chose sur Oracle par exemple, aucun soucis.

    Je peux aussi passer par des tables en mémoire au passer par des procédures stockées mais je voudrais comprendre pourquoi cela est-il impossible sur MySql.

    Si quelqu'un à une soluce je suis preneur.

    Daniel

  2. #2
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Je n'ai pas de solution spécifique à ton problème mais j'avoue ne pas comprendre pourquoi tu ne passes pas par un JOIN ?

  3. #3
    Membre Expert
    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
    Par défaut
    Normalement, il est juste impossible d'avoir deux DataReader ouverts. Donc, il faut fermer le premier avant d'en ouvrir un second.

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5
    Par défaut
    J'ai trouvé ceci dans la Faq de MySql :
    Comment pallier l'absence de requêtes imbriquées dans les versions < 4.1 ?
    http://mysql.developpez.com/faq/?pag..._sous_requetes

    Ce qui veut dire qu'à partir de la version 4.1 les requêtes imbriquées sont maintenant supportées. logique d'informaticien
    Je suis avec la version 5.xxx avec mon serveur MySql

    Maintenant, c'est vrai que je peux passer par les jointures, je vais même passer par les jointures, mais parfoit dans le code il m'est plus rapide et simple d'avoir plusieurs DataReaders ouvert en même temps.

  5. #5
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Citation Envoyé par jesuis Voir le message
    il m'est plus rapide et simple d'avoir plusieurs DataReaders ouvert en même temps.
    Euh ... En général, la jointure est le plus rapide. (cependant, avec certaines bases - entre autre SqLite - la jointure peut être très très lente si il n'y a pas d'index sur la clef de jointure, il fait donc en mettre un).

  6. #6
    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
    Par défaut
    Citation Envoyé par jesuis Voir le message
    mais parfoit dans le code il m'est plus rapide et simple d'avoir plusieurs DataReaders ouvert en même temps.
    Et c'est souvent plus sale aussi. Autant utiliser les possibilités de chaque système plutôt que de trouver des rustines prétendues plus efficaces.
    Besoin d'un MessageBox amélioré ? InformationBox pour .NET 1.1, 2.0, 3.0, 3.5, 4.0 sous license Apache 2.0.

    Bonnes pratiques pour les accès aux données
    Débogage efficace en .NET
    LINQ to Objects : l'envers du décor

    Mon profil LinkedIn - MCT - MCPD WinForms - MCTS Applications Distribuées - MCTS WCF - MCTS WCF 4.0 - MCTS SQL Server 2008, Database Development - Mon blog - Twitter

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5
    Par défaut
    Merci pour votre aide.
    Je vais allez travailler du côté de chez Join.


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

Discussions similaires

  1. vb.net & Mysql : The connection is already open.
    Par gastoncs dans le forum VB.NET
    Réponses: 5
    Dernier message: 22/10/2014, 19h13
  2. mysql adapter is already open
    Par zeusensa dans le forum VB.NET
    Réponses: 3
    Dernier message: 07/04/2011, 13h41
  3. MySQL--SQL Serveur -- DataReader "universel"
    Par TheBlackReverand dans le forum C#
    Réponses: 9
    Dernier message: 02/12/2007, 15h52
  4. mysql error# 2005
    Par battle dans le forum Administration
    Réponses: 2
    Dernier message: 11/01/2007, 16h18
  5. (Problème) Utilisation de l'API mySQL [Delphi 2005 Perso]
    Par will-scs dans le forum Bases de données
    Réponses: 2
    Dernier message: 08/08/2005, 18h26

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