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 :

"Purger" une connexion à une base de données


Sujet :

VB.NET

  1. #1
    Membre régulier Avatar de gnusti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2012
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2012
    Messages : 55
    Points : 77
    Points
    77
    Par défaut "Purger" une connexion à une base de données
    Bonjour,

    Je voulais savoir si il existait un moyen de "purger" une connexion à une base de données sans avoir à faire un dispose...

    J'effectue des traitements longs avec de très nombreux accès à ma base de données et je suis actuellement obligé d'ajouter des Dispose + Close + reconnexion pour éviter l'exception suivante :
    Impossible d'ouvrir plus de tables.
    Ces déco-reco régulières m'empêchent d'optimiser le traitement (obligé de redéfinir ma requête, de recréer mes paramètres...)

    Pour info, le traitement actuel prend aux alentours d'une heure non-stop (beaucoup de vérifications de droits, de gestion de dates, de tables à interroger...)

    Sans compter la mémoire utilisée par ce lourd traitement dans le cas ou je ne libère pas la connexion (s'ensuit un ralentissement de l'application...)

    Donc si vous avez un moyen de mettre le cache de la connexion à 0 ou autre chose de similaire, je suis preneur.

    Autre info, la base est une base Access (j'ai honte mais je n'ai pas eu le choix malgrès mes diverses propositions )

    Merci

  2. #2
    Modérateur
    Avatar de DotNetMatt
    Homme Profil pro
    CTO
    Inscrit en
    Février 2010
    Messages
    3 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : CTO
    Secteur : Finance

    Informations forums :
    Inscription : Février 2010
    Messages : 3 611
    Points : 9 742
    Points
    9 742
    Billets dans le blog
    3
    Par défaut
    Est-ce que tu utilises la méthode Dispose() de ton objet xxxCommand (OdbcCommand par exemple) ?

  3. #3
    Membre régulier Avatar de gnusti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2012
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2012
    Messages : 55
    Points : 77
    Points
    77
    Par défaut
    Je ne fais pas de dispose sur la command mais sur la connexion.

    Quel est l'objet qui "gonfle" ? La connexion ou la commande ?

    Mais faire un dispose sur ma command m'obligera a redéfinir le commandText ainsi que les paramètres à chaque fois...

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

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 179
    Points : 25 133
    Points
    25 133
    Par défaut
    c'est une limitation d'access, .net n'y est pour rien
    .dispose ferme une connexion (tout comme .close), sauf qu'en plus il libère la mémoire que la variable utilise

    http://support.microsoft.com/default...B;EN-US;165272

  5. #5
    Membre régulier Avatar de gnusti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2012
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2012
    Messages : 55
    Points : 77
    Points
    77
    Par défaut
    Tant pis

    Je fais faire des Dispose réguliers au détriment de l'optimisation

    A moins qu'il n'y ai un réglage à faire du côté d'Access lui-même ?

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

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 179
    Points : 25 133
    Points
    25 133
    Par défaut
    il faudrait plutot demander chez access que chez vb.net ...

  7. #7
    Modérateur
    Avatar de DotNetMatt
    Homme Profil pro
    CTO
    Inscrit en
    Février 2010
    Messages
    3 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : CTO
    Secteur : Finance

    Informations forums :
    Inscription : Février 2010
    Messages : 3 611
    Points : 9 742
    Points
    9 742
    Billets dans le blog
    3
    Par défaut
    Je confirme les dires de Pol63, eux-même confirmés par le lien MSDN Donc pas de réglage côté Access...

  8. #8
    Membre régulier Avatar de gnusti
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2012
    Messages
    55
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2012
    Messages : 55
    Points : 77
    Points
    77
    Par défaut
    Merci pour les réponses.

    J'ai apporté des oledbCommand.dispose() un peu partout. Ca fonctionne pour l'instant, on va faire des tests de montée en charge la semaine prochaine pour confirmer ça.

    Sinon je les forcerais à changer de BDD

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 06/07/2009, 01h04
  2. Ajouter une connexion de base de données
    Par Papy214 dans le forum Windows Forms
    Réponses: 5
    Dernier message: 30/06/2009, 18h33

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