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

SQL Oracle Discussion :

[oracle] Comment optimiser mon select ?


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Août 2010
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2010
    Messages : 10
    Par défaut [oracle] Comment optimiser mon select ?
    Bonjour,


    Je suis en stage dans une boite, et on me demande d'optimiser un outil VBA qui utilise une base de donnees oracle .

    Des lenteurs sont présentes, mon select dure 20 minutes car il parcourt les donnees en partant de 0... Comment le faire commencer a 50000 par exemple afin de cibler les recherches (les resultats que j'attends bien souvent sont vers la fin) ? OU une autre idée que la mienne serait plus judicieuse ?


    Autres choses, comment optimiser le transfert de données sur feuilles à votre avis ?
    Perso je pense à faire des transfert de gros blocs et travailler sous VBA, qu'en pensez vous ?




    Merci beaucoup par avance pour toute intervention

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Avec votre requête, ce serait probablement plus simple !

  3. #3
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    et une requête qui commence à 50000 ça ne veut strictement rien dire : les données ne sont pas ordonnées dans une table. Une table c'est un sac de bille, pas une étagère

  4. #4
    Membre Expert Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Par défaut
    Salut !

    Cf. Waldar : avec la requête, c'est sans aucun doute mieux.

    Et pour faire suite à Orafrance, il faut qu'on sache ce que tu cherches fonctionnellement :
    Quelques / beaucoup de lignes ?
    Comment identifies-tu les lignes dont tu as besoin ?
    (Les dernières... par rapport à une date ? Autre chose ?)

    Ce qui peut améliorer drastiquement les performances d'une appli qui fait des requêtes sur une base, ça peut être également les indexes disponibles...

  5. #5
    Membre averti
    Inscrit en
    Août 2010
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2010
    Messages : 10
    Par défaut
    Merci pour vos réponses,

    orafrance : Au temps pour moi, je visualise mal le processus

    La requete est du type "select sum(decode(task,'request','1','0')) Request,sum(decode(task,'incident','1','0')) Incident,count(*) " avec un for *16 .

    Concretement, mon responsable va vouloir connaitre la somme des tâches ou temps passés sur une tâche mais toujours sur le mois dernier...

    @pacmann: Je cherche surtout à retourner le chiffre attendu, soit un "temps passés" à virgule ou soit un nombre entier... donc c'est le plus souvent 1 voire 2 lignes (je parle du gros de l'outil)

    J'identifies les lignes par l'équipe dont fait partie la personne, le type de tâche, et d'autres paramètres comme si la tâche demande plusieurs jours etc....

    Et les lenteurs d'apres moi proviennent surtout d'un truc tout bête ... l'outil se connecte à chaque fois a la BDD pour retourner un chiffre (le temps passés ou le nombre de tâches) .. c'est pour cela que je me suis dis qu'il fallait mieux retourner de gros blocs et travailler ça sous VBA ... non ?

    Cordialement

  6. #6
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    Citation Envoyé par sousou94 Voir le message
    Concretement, mon responsable va vouloir connaitre la somme des tâches ou temps passés sur une tâche mais toujours sur le mois dernier...
    Faudrait au moins un index sur la date à ce moment là

    Citation Envoyé par sousou94 Voir le message
    Et les lenteurs d'apres moi proviennent surtout d'un truc tout bête ... l'outil se connecte à chaque fois a la BDD pour retourner un chiffre (le temps passés ou le nombre de tâches) .. c'est pour cela que je me suis dis qu'il fallait mieux retourner de gros blocs et travailler ça sous VBA ... non ?
    Ou faire une requête qui retourne tous les chiffres d'un coup... mais c'est vrai que se reconnecter à chaque fois c'est moyen

  7. #7
    Membre Expert Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Par défaut
    for * 16 ?

    Si c'est parce qu'il veut l'indicateur pour les 16 équipes, tu peux faire une seule requête en faisant un GROUP BY equipe (au lieu de mettre à chaque fois dans le filtre), et traiter comme tu le dis en VBA le résultat.

    ... il n'en reste pas moins que comme dit Orafrance, un index sur la date te permettra probablement de ne pas te taper les lignes de "1 à 50000"

  8. #8
    Membre averti
    Inscrit en
    Août 2010
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Août 2010
    Messages : 10
    Par défaut
    On arrive à mes limites , comment faire cet index ? sur que base ? je ne visualise pas ...

    La requête ne peut retourner tout les chiffres d'un coup, je pense pas du moins, car il y a des sum mais aussi des requêtes sans "sum" ...mais il est possible au moins de passerde 16 à 20 requêtes qui se ressemblent à 5-6 .


    pacmann : "group by" sur quoi ? sur un critere exemple l'équipe dont fait partie la personne ?

Discussions similaires

  1. [Optimisation] Comment optimiser mon architecture ?
    Par buzzkaido dans le forum C++
    Réponses: 6
    Dernier message: 09/05/2007, 13h59
  2. Comment optimiser mon serveur ?
    Par guidav dans le forum Requêtes
    Réponses: 8
    Dernier message: 27/02/2007, 17h47
  3. Réponses: 9
    Dernier message: 07/11/2006, 14h12
  4. Comment récupérer mon SELECT en mémoire ?
    Par Invité dans le forum Bases de données
    Réponses: 3
    Dernier message: 14/03/2006, 05h09
  5. [C#] Comment optimiser mon constructeur ?
    Par blbird dans le forum C#
    Réponses: 2
    Dernier message: 19/01/2006, 14h41

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