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

VB.NET Discussion :

MySQL et deux datareader


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Août 2010
    Messages : 277
    Par défaut MySQL et deux datareader
    Bonsoir,

    J'ouvre un datareader, puis j'ai besoin d'en ouvrir un autre (provenant d'une autre requete) avant de fermer le premier.
    je n'ai ouvert qu'une connexion que je referme a la fin de la procedure.

    Comment puis je faire?
    Mysql me retourne une erreur me disant qu'il y a déja un datareader d'ouvert (je le sais et j'en ai besoin )

    Merci d'avance

  2. #2
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 200
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 200
    Par défaut
    soit ouvrir 2 connexions, soit mieux écrire tes 2 requetes pour qu'elles tiennent en une seule (très souvent faisable)
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  3. #3
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Août 2010
    Messages : 277
    Par défaut
    Merci de ta réponse Pol63

    C'est ce que j'ai fais (ouvrir 2 connexions) mais je trouve ca pas trés élégant.
    De plus les connexions reste ouvertes sur le serveur (un certain temps puis se ferme) si je ferme mon programme alors la connexion est fermé completement.
    J'ai meme fait passer le garbage collector, ca reste ouvert quand meme, voila pourquoi j'aurai aimé n'avoir a me servir que d'une connexion.


    Pas vraiment possible de grouper mes requetes, elles ne sont pas dans les memes procedures, et certaines ne sont lancé que si une condition est remplie.

  4. #4
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 200
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 200
    Par défaut
    il n'y aucun mal à ouvrir plusieurs connexions, tu peux même en ouvrir des centaines sur plusieurs threads, un serveur de base de données est fait pour ca
    pour fermer une connexion il faut faire .close (ou .dispose) quand tu as fini de l'utiliser (il faudrait donc éviter d'ouvrir une connexion pendant toute la durée de l'exécution de l'app mais juste à chaque besoin, bien que ca ne pose pas de soucis particulier non plus)

    le garbage collector ne sert qu'à vider la ram de ce qui ne sert plus, il est par ailleurs appelé tout seul de temps en temps

    concernant le groupage de requete, le langage sql permet des tas de choses, même avec des conditions et des tas de requetes il est rarement impossible de faire tout sur une seule requete (2 requetes concaténées dans le commandtext s'exécuteront chacune leur tour comme du code vb)
    il est même possible d'avoir des variable dans le langage sql
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  5. #5
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Août 2010
    Messages : 277
    Par défaut
    Pour le .close, je le fais. pourtant quand je regarde sur le serveur la connexion est resté ouverte (du moins j'en ai l'impression).
    C'est pour ca que j'ai fais passer le GC afin d'etre sur que ce n'etait pas autre chose qui me maintenait un canal ouvert sur le serveur.

    Aurais tu un lien pour le lanquage des requetes MySQL cela m'a l'air intéressant de pouvoir faire des conditions dans les requetes.

    Attention c'est MySQL que j'utilise (pas SQL) j'ai cru comprendre que ce n'était pas les même requêtes (enfin pas tout a fait)

    Merci

  6. #6
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 200
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 200
    Par défaut
    je ne connais pas trop mysql, mais en général les sgbdr ont un pool de connexion, quand tu fermes une connexion, le serveur la garde et la prochaine fois que tu demandes une connexion il te donne celle là
    ou sinon peut etre que l'info n'est pas rafraichie immédiatement dans mysql

    concernant le langage sql, il faudrait peut etre chercher sur le site de l'éditeur ou dans l'aide
    mysql ne supporte pas beaucoup de normes du langage déjà, donc pas sur qu'ils aient fait un langage avec beaucoup de possibilités
    sur sql server le langage s'appelle transact SQL, il respecte la plupart des normes sql et contient de nombreuses instructions propres à sql server
    il est alors possible d'écrire des choses du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    DECLARE @variable bigint
    IF EXISTS(SELECT 1 FROM telletable WHERE condition)
      SET @variable = (select valeur from autretable where condition)
     
    IF @variable IS NULL
      INSERT INTO (...)
    ou encore des requetes récursives, récupérer la dernière valeur d'autoincrément générée, des boucles, et plein d'autres choses ...

    sql server express est gratuit, c'est en général un allié de choix pour une appli .net ...
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

Discussions similaires

  1. recherche sur table mysql avec deux index
    Par Invité1 dans le forum Bases de données
    Réponses: 3
    Dernier message: 20/05/2010, 11h41
  2. Réponses: 6
    Dernier message: 18/03/2008, 10h32
  3. [MYSQL]VS 2005 DataReader already open
    Par jesuis dans le forum C#
    Réponses: 6
    Dernier message: 04/01/2008, 15h25
  4. MySQL--SQL Serveur -- DataReader "universel"
    Par TheBlackReverand dans le forum C#
    Réponses: 9
    Dernier message: 02/12/2007, 15h52
  5. mysql: relier deux enregistrement d'une même table
    Par __antoine__ dans le forum Administration
    Réponses: 2
    Dernier message: 14/06/2007, 23h14

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