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

Requêtes MySQL Discussion :

Optimiser requete select dans un select


Sujet :

Requêtes MySQL

  1. #1
    Membre à l'essai
    Inscrit en
    Juillet 2012
    Messages
    34
    Détails du profil
    Informations forums :
    Inscription : Juillet 2012
    Messages : 34
    Points : 22
    Points
    22
    Par défaut Optimiser requete select dans un select
    Bonjour,

    J'ai une requête qui suit le schéma suivant:
    Un CSN a 1-n supplier et un supplier à 1-n CSN.
    Je veux renvoyer pour chaque CSN le supplier le plus ancien, et celui la seulement.

    J'ai alors fait la requête suivante qui fonctionne mais est très lente. Comment peut on optimiser cette requête pour qu'elle soit significativement plus rapide?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    select CSN
    From CSNLIST csn 
       LEFT JOIN
    	(
    		SELECT supplierDesc , MIN(dateAdded) AS minsolved,idCSN,sup.idSupplierCode 
    		FROM ADS_schema.FK_CSN_SUPPLIER fkSup 
    		JOIN ADS_schema.SUPPLIER sup ON sup.idSupplierCode = fkSup.idSupplierCode 
    		GROUP BY idCSN
    	) minDate  ON  csn.idCSN = minDate.idCSN
    JOIN ...
    Merci de votre aide
    Florent

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    bonjour,


    Postez le plan d’exécution de la requete

  3. #3
    Membre à l'essai
    Inscrit en
    Juillet 2012
    Messages
    34
    Détails du profil
    Informations forums :
    Inscription : Juillet 2012
    Messages : 34
    Points : 22
    Points
    22
    Par défaut
    J'ai mis le résultat du explain en piece jointe pour que ca reste lisible.

    Le probleme de ma requete c'est que mon sub-select est très lent car il n'utilise pas les filtres du reste de la requete mais n'y a t-il pas mieux que de faire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select .... from TABLE
    JOIN ...
    LEFT JOIN (select ... min(date), .... JOIN à nouveau toutes les tables pour filtrer)
    Images attachées Images attachées  

  4. #4
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    j'avais pas vu mais la sous-requete ne veut pas dire grand chose.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT supplierDesc , MIN(dateAdded) AS minsolved,idCSN,sup.idSupplierCode 
    		FROM ADS_schema.FK_CSN_SUPPLIER fkSup 
    		JOIN ADS_schema.SUPPLIER sup ON sup.idSupplierCode = fkSup.idSupplierCode 
    		GROUP BY idCSN

    D'après votre description j'en déduis le mcd suivant :
    CSNLIST-0,n-----possede----0,n-SUPPLIER

    Le mpd doit donc avoir cette tete la :
    CSNLIST(idCSN, ....)
    SUPPLIER(idSupplierCode, .....)
    FK_CSN_SUPPLIER(#idCSN, #idSupplierCode, dateAdded)


    Donc pour retrouver le supplier le plus ancien pour chaque idSCN :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT idSCN, idSupplierCode
    FROM FK_CSN_SUPPLIER fk1
    INNER JOIN (
     SELECT idSCN, min(dateAdded) as minDate
     FROM FK_CSN_SUPPLIER fk
     group by idSCN) as fk2 on fk1.idSCN = fk2.idSCN AND fk1.dateAdded = fk2.minDate

    Docn est-ce que cette requete correspond à votre besoin ? si oui est-elle lente ? si oui mettez le plan d'execution

Discussions similaires

  1. [MySQL] requete pour faire un select dans toutes les tables pour trouver le titre
    Par japhettchabao dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 12/09/2014, 20h02
  2. [AC-2003] Requete paramétrée dans le select + VBA
    Par saigon dans le forum VBA Access
    Réponses: 2
    Dernier message: 28/08/2009, 15h49
  3. resultat requete SQL d'un select dans variable vb
    Par seb_06 dans le forum Requêtes et SQL.
    Réponses: 12
    Dernier message: 11/10/2004, 16h29
  4. [firebird] sous select dans un select
    Par gdido dans le forum SQL
    Réponses: 2
    Dernier message: 14/05/2004, 09h57
  5. [Sybase] Select dans une select loop en C
    Par Claudio dans le forum Sybase
    Réponses: 2
    Dernier message: 29/04/2003, 18h06

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