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 :

performances de rs.next()


Sujet :

JDBC Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Avril 2004
    Messages
    101
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 101
    Par défaut performances de rs.next()
    Bonjour,

    En essayant d'optimiser mon appli j'ai mis en place un pooling sur l'interrogation d'une vue. Le but était de traiter un grand nombre de données par petits lots en pensant que ça irait plus vite et prendrait moins de mémoire.

    Donc j'ai une requête de sélection (read only) sur une vue.
    Quelque soit le nombre d'enregistrement la requête prend à peu près le même temps : 1 à 2s.
    Par contre une fois la requête effectuée et le resultset obtenu je fais les resultset.next()... et c'est là que ça devient étrange :

    moins il y a de tuple dans mon resultset plus le premier resultset.next est long !?!

    exemple : il y a 1511 enregistrements dans ma vue
    ---------------------------+---------------------+----------------------
    nombre d'enregistements.....| durée d'exécution.....| durée d'exécution
    demandé parmis les 1511.....| de la requête...........| du 1er resultset.next
    ---------------------------+---------------------+----------------------
    TOUS...............................|.................1031 ms |..................7631 ms
    ---------------------------+---------------------+----------------------
    500.................................|...................711 ms |..................7540 ms
    ---------------------------+---------------------+----------------------
    100.................................|...................601 ms |.................50493 ms
    ---------------------------+---------------------+----------------------
    50...................................|...................611 ms |.................48900 ms
    ---------------------------+---------------------+----------------------

    quelqu'un peut-il m'expliquer cela ?


    JAVA 1.4
    Base de donnée : SQL Server 2000 (vue sur une base liée : DB2)
    Driver : net.sourceforge.jtds.jdbc.Driver

  2. #2
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Billets dans le blog
    1
    Par défaut
    Peux-tu mettre le code de ton traitement ?

    A+
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre confirmé
    Inscrit en
    Avril 2004
    Messages
    101
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 101
    Par défaut
    voici un bout du code, bien qu'il n'y ai rien de particulier je pense :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    stmt = conn.createStatement();
    stmt.setQueryTimeout(timeout*60*1000); // 12 mn
    long start = System.currentTimeMillis();
    rset = stmt.executeQuery(query);
    System.out.println("createStatement " + (System.currentTimeMillis() - start));
    start = System.currentTimeMillis();
    while (!suspend && rset.next()) {
         System.out.println("rset.next() " + (System.currentTimeMillis() - start));
         ref = rset.getString("ref");
         ...
    }

  4. #4
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par _Eric_ Voir le message
    ... bien qu'il n'y ai rien de particulier je pense :
    C'est le moins qu'on puisse dire... mais je voulais être sûr que tu n'utilises pas de fonctionalités particulières des statements.

    Le tableau de temps que tu as donné correspond à la lecture :
    1- de tous les enregistrements
    2- des 500 premiers enregistrements
    3- des 100 premiers enregistrements
    4- des 50 premiers enregistrements

    ou faut-il comprendre :
    1- idem
    2- renvoi d'un bloc de 500 enregistrements (autres que les 500 premiers)
    etc...

    Je le demande parce que ça expliquerait le temps croissant (puisqu'il faudrait bien lire les enregistrements des blocs déjà lus)

    Je suis clair ?
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre confirmé
    Inscrit en
    Avril 2004
    Messages
    101
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 101
    Par défaut
    il s'agit toujours des permiers enregistrement,
    j'ai redémarré completement l'application entre chaque test

  6. #6
    Membre confirmé
    Inscrit en
    Avril 2004
    Messages
    101
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 101
    Par défaut
    et j'ai fais les tests plusieurs fois, avec des temps similaires dans chaque cas

Discussions similaires

  1. [maintenance][performance] Que faire comme maintenance ?
    Par woodwai dans le forum PostgreSQL
    Réponses: 5
    Dernier message: 06/11/2003, 15h39
  2. [ POSTGRESQL ] Problème de performance
    Par Djouls64 dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 26/05/2003, 16h18
  3. [JDBC][connexion persistante] performances avec JDBC
    Par nawac dans le forum Connexion aux bases de données
    Réponses: 6
    Dernier message: 06/05/2003, 10h37
  4. Next & Previous
    Par bidson dans le forum XMLRAD
    Réponses: 13
    Dernier message: 01/05/2003, 09h35
  5. performance entre 3DS, ase, asc ...
    Par amaury pouly dans le forum OpenGL
    Réponses: 3
    Dernier message: 24/03/2003, 11h41

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