|
Publicité ' | |||||||||||||||||||||||
|
|
#1 | ||
|
Invité de passage
![]() Développeur Web Inscription : juin 2011 Messages : 19 ![]() |
Bonjour bonjour. Je bosse actuellement sur un projet php avec une très grosse base de données contenant quelques milliards d'enregistrement. Si je viens vous voir aujourd'hui c'est que je bosse sur une optimisation de requête. Celle-ci durait plus de deux minutes avant que je mette les mains dans le cambouis, elle dure désormais une vingtaine de seconde. Mais bon, comme vous vous en doutez, 20 secondes c'est encore beaucoup trop long et il me faut une autre solution. Je ne suis pas du tout un spécialiste en SQL mais je me débrouille assez bien en général. Cependant ici, étant donné le volume de données, j'aurai besoin d'autres avis. Voila où j'en suis arrivé :
Code :
|
||
|
|
00
|
|
|
#2 |
|
Expert Confirmé
![]() Inscription : mai 2002 Messages : 1 657 ![]() |
Bonjour,
Manque le SGBD, un descriptif des tables (en particulier les relations entre vos 2 tables), les indexs en place et à priori le plan d'execution. |
|
|
00
|
|
|
#3 |
|
Invité de passage
![]() Développeur Web Inscription : juin 2011 Messages : 19 ![]() |
En effet. Donc on tourne sous postgre.
Ici nous avons donc un lien entre les tables lien_champ__phrase et lien_niveau__phrase qui sont liées par le champ _fils de lien_niveau__phrase et le champ _fils de lien_champ_phrase. Après ceci est déjà visible dans la requête. Il n'y a pas d'index. Pour ce qui est du plan d'exécution, que voulez-vous dire? |
|
|
00
|
|
|
#4 | ||
|
Membre éprouvé
![]() Inscription : mai 2002 Messages : 535 ![]() |
Vous pouvez essayer ceci (sans aucune garantie
l'idée sous-jacente est d'utiliser dans un premier temps l’accès à la table "LCP" (devrait être indexée sur "père" normalement) avant de faire la jointure sur LNP ===================================================== PS : Comment générez vous le contenu du "in" PS2 : quelles sont les index sur vos 2 tables Code :
__________________
Signé : Capitaine Jean-Luc Picard |
||
|
|
00
|
|
|
#5 | |||
|
Expert Confirmé
![]() Inscription : mai 2002 Messages : 1 657 ![]() |
Citation:
Citation:
Oki dans ce cas, il faut au minima créer un index sur votre condition de jointure. PostgreSQL ne crée pas par défaut un index sur les foreign key. Si pas suffisant il faudrai créer un index (au choix selon les temps de réponses) sur la table lien_champ__phrase : - _pere, _fils - _fils, _pere Citation:
PgAdmin dispose d'une version texte / graphique, sinon il faut faire : |
|||
|
|
00
|
|
|
#6 |
|
Invité de passage
![]() Développeur Web Inscription : juin 2011 Messages : 19 ![]() |
Merci de votre réponse et de votre intérêt.
Donc au niveau des indexes, rien de spécial. Une clé primaire sur un champ nommé "_id" sinon c'est réellement tout. En fait le système mis en place fait que des tables nommées objet_nomobjet, sont liées par des tables lien_objet1__objet2 par les champs _pere et _fils. Pour ce qui est du IN. Il est généré en php avec la fonction implode sur une requête précédente. J'ai testé votre solution mais le temps est globalement identique, à une seconde près. |
|
|
00
|
|
|
#7 |
|
Membre Expert
![]() Laure Consultante en Business Intelligence Inscription : avril 2007 Messages : 983 ![]() |
Le plan d'exécution va te permettre de voir ce qui te prend le plus de ressource dans ta requête SQL.
Et tu nous postes le résultat. Mais déjà avec un index tu es quasi sûr que ta requête sera plus rapide.
__________________
~ Lola ~ Ne pas oublier : et aussi :
|
|
|
00
|
|
|
#8 | ||
|
Invité de passage
![]() Développeur Web Inscription : juin 2011 Messages : 19 ![]() |
Le voila donc.
Code :
|
||
|
|
00
|
|
|
#9 |
|
Expert Confirmé
![]() Inscription : mai 2002 Messages : 1 657 ![]() |
explain analyze sinon on ne voit pas ce qui ne pourrai pas aller ! (et ne virez pas l'indentation c'est important pour voir les étapes)
edit : il fait un table scan de la table lien_niveau__phrase. Avez-vous mit un index sur lien_niveau__phrase._fils comme je le vous conseillais ? |
|
|
00
|
|
|
#10 | ||
|
Invité de passage
![]() Développeur Web Inscription : juin 2011 Messages : 19 ![]() |
Code :
|
||
|
|
00
|
|
|
#11 |
|
Invité de passage
![]() Développeur Web Inscription : juin 2011 Messages : 19 ![]() |
Pas encore, je vais voir avec mon équipe et essayer ça.
|
|
|
00
|
|
|
#12 | ||
|
Invité de passage
![]() Développeur Web Inscription : juin 2011 Messages : 19 ![]() |
Bon et bien je suis allé voir la structure de la base de données. Tous les champs de toutes les tables sont indexées. Je ne sais trop pourquoi. J'ai donc supprimé tous les index qui ne me paraissaient pas utiles dans mes deux tables et je n'ai gardé que les index sur _id, _fil et _pere dans ces deux tables. Cependant je tourne toujours à 20 secondes.
Code :
|
||
|
|
00
|
|
|
#13 |
|
Expert Confirmé
![]() Inscription : mai 2002 Messages : 1 657 ![]() |
Y a combien de ligne dans votre table lien_niveau__phrase ?
Votre plan ne me semble pas "mauvais" compte tenu du travaille demandé (jointure Là où il perd le plsu de temps c'est sur la jointure entre vos deux tables, s'il n'utilise pas l'index présent c'est qu'il estime que ca sera encore plus long. Vous pouvez peut-être vérifier ceci en faisant : puis refaire un explain analyze de votre requête avec cette même session |
|
|
00
|
|
|
#14 |
|
Invité de passage
![]() Développeur Web Inscription : juin 2011 Messages : 19 ![]() |
8 804 781 lignes dans cette table.
|
|
|
00
|
|
|
#15 |
|
Expert Confirmé
![]() Inscription : mai 2002 Messages : 1 657 ![]() |
ok, il n'utilisera jamais votre index dans ces conditions vu qu'il sélectionne presque toute les lignes de la table lien_niveau__phrase pour satisfaire votre requête.
Pour moi votre plan est donc correct. D'autre personne auront peut-être un avis différent. |
|
|
00
|
|
|
#16 |
|
Invité de passage
![]() Développeur Web Inscription : juin 2011 Messages : 19 ![]() |
D'accord merci pour l'aide apportée. J'ai remodifié un peu les index et j'ai fini par descendre à un temps d'exécution d'après php d'environ 10 secondes ce qui n'est déjà pas si mal. Après je pense que c'est encore trop long donc je vais essayer de voir avec le chef si on ne peut pas passer cette étape qui n'est pas forcément vitale. Je continuerai de jeter un oeil sur ce sujet au cas où quelqu'un voit autre chose.
Merci encore. |
|
|
00
|
|
|
#17 | ||
![]() ![]() |
Sans garantie, vous pouvez essayer celle-ci :
Code :
__________________
Email : http://scr.im/waldar |
||
|
00
|
|
|
#18 |
|
Invité de passage
![]() Développeur Web Inscription : juin 2011 Messages : 19 ![]() |
Merci. Cela fonctionne mais le temps d'exécution s'en trouve triplé désolé.
|
|
|
00
|
|
|
#19 | |
![]() ![]() |
Je rebondis sur ce point :
Citation:
On peut voir cette autre requête ?
__________________
Philippe Leménager. Ingénieur d'étude à l'École Nationale de Formation Agronomique. Mon blog sur la conception des BDD, le langage SQL, le PHP avec Zend Framework... « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau) À la maison comme au bureau, j'utilise Mandriva Linux ou Mageïa ! Soutenons l'industrie logicielle française ! Linuxiens, comptez-vous ! |
|
|
00
|
Copyright © 2000-2012 - www.developpez.com