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

JDBC Java Discussion :

Lenteur à la sortie du .next()


Sujet :

JDBC Java

  1. #1
    Nouveau membre du Club
    Inscrit en
    Novembre 2009
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 56
    Points : 38
    Points
    38
    Par défaut Lenteur à la sortie du .next()
    Bonjour,

    J'ai une requête plutôt simple du genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT MaColonne1,MaColonne2,MaColonne3 FROM MaTable WHERE .....
    Le tout d'une application vers une BD ACCESS 2003.

    La requête retourne entre 60 et 70 000 lignes.

    J'arrive à obtenir mes données sans problème, sauf que l'application semble rester coincé au dernier res.next() même si je ne fais qu'afficher qu'un system.out.println();

    Il affiche les 70 000 getDates() en 3 secondes, et reste coincé 3 minutes sur le dernier next()...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
      ResultSet res = statement.executeQuery("SELECT MaColonne1,MaColonne2,MaColonne3 FROM MaTable WHERE .....");
     
     while (res.next()) {
               System.out.println("next... "+getDateTime());
    }
    System.out.println("fin next... "+getDateTime());
    Résultats ( J'ai mis que le dernier next et le fin next ) :

    next... 2014-11-03 11:22:21.2221
    fin next... 2014-11-03 11:24:34.2434
    Plus le nombre de données et long et plus le temps entre le dernier next et la sortit du next est long.
    À 70 000 donné, ça prend presque 3 minutes avant de sortir.

    Est-ce normal ? Qu'est-ce qui peux causer sa et surtout, auriez-vous une idée pour faire en sorte que le dernier next qui retourne false, ne prenne pas autant de temps.

    Merci !!!

  2. #2
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,



    Quel est le driver JDBC que tu utilises ? Le problème vient sûrement de là...


    a++

    PS : et tu devrais libérer proprement ton ResultSet et ton Statement via un try-with-ressource (ou un try/finally sous Java 6 et inférieur)

  3. #3
    Nouveau membre du Club
    Inscrit en
    Novembre 2009
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Novembre 2009
    Messages : 56
    Points : 38
    Points
    38
    Par défaut
    Bonjour,

    Merci pour votre réponse.

    Ma connection et mon statement sont bien entendu fermé dans un finally() ( java 6 )

    J'utilise le driver JdbcOdbcDriver de sun.

    sun.jdbc.odbc.JdbcOdbcDriver

    Est-ce qu'un autre driver pourrait m'éviter ce problème ?

  4. #4
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Ce driver n'est ni supporté ni conseillé par Oracle : http://docs.oracle.com/javase/7/docs...bc/bridge.html

    Il vaudrait mieux se tourner vers un "vrai" driver Access (mais perso ceci est en dehors de mes connaissances).


    a++

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2009
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Août 2009
    Messages : 11
    Points : 11
    Points
    11
    Par défaut
    En effet, il semble y avoir un autre driver "officiel"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    com.ms.jdbc.odbc.JdbcOdbcDriver
    Mais l'explications sur le site de Microsoft est très flou et ne semble pas adapté au logiciel que j'ai.

    Enfin bref, tant pis. Si il n'y a pas de solution, je vais vivre avec ce problème.....

    En vous remerciant !

  6. #6
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Tu pourrais peut être revoir le code pour commencer par faire un select count(*) et eviter le dernier next() (c'est à dire celui qui retourne false)

    Ou alors tu revois ta boucle en

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    do {
    } while (!rs.isLast())
    Au passage, mauvaise idée le driver les ponts jdbc/odbc en java. Ce driver a disparu en java 8, fini, il n'existe plus.

    Faut voir aussi comment tu établis ta connection. Via un DSN ou en mettant le nom du fichier access dans l'URL

    Il existe des driver pure java pour access, mais ils ont certaines contraintes sur le type de structure dans la base access. Notement les index et les règles de tri

    http://ucanaccess.sourceforge.net/site.html

Discussions similaires

  1. Lenteur d'une boucle For each next
    Par Val2000 dans le forum Macros et VBA Excel
    Réponses: 15
    Dernier message: 27/05/2013, 11h41
  2. [XL-2007] Boucles For Each Next: problème de défilement des feuilles avec lenteur d'exécution
    Par camelia.w dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 24/12/2011, 20h08
  3. Réponses: 17
    Dernier message: 19/11/2010, 03h54
  4. Problème lenteur JDBC / ACCESS / ResultSet next()
    Par SebastianPx dans le forum JDBC
    Réponses: 11
    Dernier message: 22/04/2009, 20h29
  5. récupérer la valeur de sortie d'un thread
    Par jakouz dans le forum Langage
    Réponses: 3
    Dernier message: 31/07/2002, 11h28

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