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 :

Jointure, performance lamentable


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert Avatar de fregolo52
    Homme Profil pro
    Développeur C
    Inscrit en
    Août 2004
    Messages
    2 366
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur C

    Informations forums :
    Inscription : Août 2004
    Messages : 2 366
    Par défaut Jointure, performance lamentable
    Bonjour,

    J'ai installé MySQL sous Windows avec le wizard, configuration de l'instance du serveur :
    - version developpeur
    - multi-fonctionnel

    Je ne sais pas si je m'y suis pris comme un pied.

    Je fais une jointure entre 2 tables (de respectivement 60000 et 100000 lignes).

    Le résultat de la requête devrait retourner 11000 lignes, phpmyadmin ou MySQL Query Browser ne me rendent pas la main (ou peut être après plusieurs dixaines de minutes).

    Je suis sous Windows, j'ai donc utilisé SQL Server Express pour comparer.
    Le résultat est instantané alors que j'ai migré la base à l'arrache sans clé primaire ni index.

    Ce qui est bizarre, c'est que j'ai déjà fait le même genre de comparaison avec une procédure stockée assez lourde en calcul, et les 2 SGDB avaient les mêmes perfs.

    Quelqu'un aurait une idée du problème ?

    Merci.

  2. #2
    Membre Expert

    Homme Profil pro
    SDE
    Inscrit en
    Août 2007
    Messages
    2 013
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : SDE

    Informations forums :
    Inscription : Août 2007
    Messages : 2 013
    Par défaut
    Bonjour,

    pourrait-on avoir le script de création des deux tables ?

  3. #3
    Membre Expert Avatar de fregolo52
    Homme Profil pro
    Développeur C
    Inscrit en
    Août 2004
    Messages
    2 366
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur C

    Informations forums :
    Inscription : Août 2004
    Messages : 2 366
    Par défaut
    Voici les scripts générés par MySQL Query Browser :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    CREATE TABLE  `production`.`downloading` (
      `index` int(11) NOT NULL auto_increment,
      `operation_number` int(9) NOT NULL default '0',
      `operator_name` varchar(30) NOT NULL,
      `pc_name` varchar(30) NOT NULL,
      `serial_number` varchar(20) NOT NULL,
      `software_version` varchar(100) NOT NULL,
      `driver_version` varchar(100) NOT NULL,
      `result` varchar(110) NOT NULL,
      `date_time` timestamp NOT NULL default CURRENT_TIMESTAMP,
      `EXE_Version` varchar(50) NOT NULL,
      `DLL1_Version` varchar(50) NOT NULL,
      `DLL2_Version` varchar(50) NOT NULL,
      `2Dstring` text NOT NULL,
      PRIMARY KEY  (`index`),
      KEY `pc_name` (`pc_name`),
      KEY `operation_number` (`operation_number`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
    et

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    CREATE TABLE  `production`.`packaging` (
      `index` int(11) NOT NULL auto_increment,
      `operation_number` int(9) NOT NULL default '0',
      `operator_name` varchar(30) NOT NULL,
      `outer_carton_number` smallint(6) NOT NULL default '0',
      `inner_carton_number` smallint(6) NOT NULL default '0',
      `serial_number` varchar(20) NOT NULL,
      `software_version` varchar(100) NOT NULL,
      `driver_version` varchar(100) NOT NULL,
      `date_time` timestamp NOT NULL default CURRENT_TIMESTAMP,
      `product_number` varchar(25) NOT NULL default '?',
      PRIMARY KEY  (`index`),
      KEY `operation_number` (`operation_number`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
    la vue est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    CREATE 
        ALGORITHM=UNDEFINED 
        DEFINER=`root`@`localhost` 
        SQL SECURITY DEFINER 
        VIEW  `production`.`stat2` 
    AS
    select `d`.`operator_name` AS `operator_name`,`d`.`pc_name` AS `pc_name`,
      `d`.`operation_number` AS `operation_number`,`d`.`serial_number` AS `serial_number`,
      `p`.`outer_carton_number` AS `outer_carton_number`, `p`.`inner_carton_number` AS `inner_carton_number`,
      `d`.`software_version` AS `software_version`,
      `d`.`result` AS `result`,`d`.`2Dstring` AS `2Dstring`,
      `d`.`date_time` AS `datedown`,`p`.`date_time` AS `datepack`
    from (`downloading` `d` 
      left join `packaging` `p` 
        on (((`d`.`operation_number` = `p`.`operation_number`) 
           and (`d`.`serial_number` = `p`.`serial_number`))));
    Y a-t-il quelque chose à configurer dans my.ini pour améliorer les perfs ?

    Merci

  4. #4
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 290
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 290
    Par défaut
    Il faudrait ajouter un index sur la colonne serial_number des deux tables, ou bien deux index combinés (operation_number, serial_number) sur les deux tables.

  5. #5
    Membre Expert Avatar de fregolo52
    Homme Profil pro
    Développeur C
    Inscrit en
    Août 2004
    Messages
    2 366
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur C

    Informations forums :
    Inscription : Août 2004
    Messages : 2 366
    Par défaut
    Merci, maintenant les perfs n'ont plus rien à voir !!! Je suis passé de 190s à 0.6s !!

    Ma vue est erronée ou incomplète, je me retrouve avec des choses bizarres :
    Par exemple :
    - dans la table downloading pour l'operation 32 j'ai le serial_number 62138574
    - Ce serial_number n'existe pas dans la table packaging
    Vu la clause de ma vue, je ne comprends pas pourquoi une ligne apparait avec ce serial_number.

  6. #6
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 290
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 290
    Par défaut
    Citation Envoyé par fregolo52 Voir le message
    Merci, maintenant les perfs n'ont plus rien à voir !!! Je suis passé de 190s à 0.6s !!

    Ma vue est erronée ou incomplète, je me retrouve avec des choses bizarres :
    Par exemple :
    - dans la table downloading pour l'operation 32 j'ai le serial_number 62138574
    - Ce serial_number n'existe pas dans la table packaging
    Vu la clause de ma vue, je ne comprends pas pourquoi une ligne apparait avec ce serial_number.

    Ta vue est en LEFT JOIN. Donc il suffit que le serial_number existe dans downloading.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [DATA] Optimisation d'une jointure : performance DATA vs PROC SQL
    Par foxrol dans le forum SAS Base
    Réponses: 3
    Dernier message: 08/02/2012, 12h15
  2. Réponses: 2
    Dernier message: 12/03/2007, 10h14
  3. [SQL Server] Jointure entre 2 tables et performances
    Par rmeuser dans le forum Langage SQL
    Réponses: 3
    Dernier message: 27/04/2006, 10h12
  4. Problème performance SELECT avec jointure
    Par Netgamer dans le forum Requêtes
    Réponses: 7
    Dernier message: 05/08/2005, 10h20
  5. Performance Jointure
    Par jflebegue dans le forum Décisions SGBD
    Réponses: 4
    Dernier message: 01/12/2004, 22h41

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