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

PHP & Base de données Discussion :

Temps de réponse [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Août 2005
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 13
    Par défaut Temps de réponse
    Bonjour,

    Voila, je viens vers vous pour un petit problème d'optimisation de requêtes.

    J'ai 2 tables : entreprise (env. 6000 enr.) et personnel (env. 10000 enr.)
    Je souhaite récupérer une table contenant les renseignements des entreprises et de son personnel.

    Ma première requête est la suivante :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    $resSQL = mysql_query("CREATE TEMPORARY TABLE table_temp1 SELECT id_entreprise, GROUP_CONCAT(CONCAT(nom, ' ', prenom)) AS nom_prenom FROM personnel GROUP BY id_entreprise");

    La deuxième :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $resSQL = mysql_query("CREATE TEMPORARY TABLE table_temp2 SELECT id_entreprise, nom_entreprise, cp_entreprise, ville_entreprise, IFNULL((SELECT nom_prenom FROM table_temp1 WHERE id_entreprise = entreprise.id_entreprise), ' ') AS nom_prenom FROM entreprise ORDER BY nom_entreprise");

    Je récupère dans table_temp2, l'ensemble des infos sur l'entreprise et les noms et prénoms du personnel (chaîne séparée par une virgule).

    Cela fonctionne, mais c'est un peut lent ....

    Auriez vous une autre solution ?

    J'ai essayé de bascule cela dans une procédure stockée, c'est pareil !
    Si j'intègre la première requête dans la deuxième, cela prend trop de temps à l'exécution et mysql tombe !

    Merci d'avance

    A+

  2. #2
    Membre Expert Avatar de riete
    Homme Profil pro
    DevWeb - Oléiculteur
    Inscrit en
    Avril 2006
    Messages
    1 193
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : DevWeb - Oléiculteur
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 193
    Par défaut
    Il y a plusieurs chose à regarder car pour faire tomber un serveur MySQL il en faut bien plus que cela

    1/ Je pense que la structure des tes tables est à revoir. Il faut que tu es in champ indéxé id_entreprise dans la table personnel ainsi qu'un champ id_personnel qui soit la clé primaire dans la table personnel.

    2/ Ta requête select peut aussi se faire en utilisant un jointure LEFT JOIN par exemple

  3. #3
    Membre averti
    Inscrit en
    Août 2005
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Août 2005
    Messages : 13
    Par défaut
    Alors là ... Bravo !!

    J'ai ajouté l'index et réuni les 2 requêtes.
    Le temps de réponse est vraiment beaucoup plus rapide.

    Merci

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

Discussions similaires

  1. temps de réponse localhost\réseau: troublant...
    Par Nickytchao dans le forum Décisions SGBD
    Réponses: 5
    Dernier message: 17/01/2005, 08h24
  2. Réponses: 5
    Dernier message: 17/11/2004, 21h29
  3. Ressources, temps de réponse, requète ...
    Par _____M_____ dans le forum Administration
    Réponses: 16
    Dernier message: 31/03/2004, 16h12
  4. Temps de réponse : objet TTable (BDE)
    Par lirva dans le forum Bases de données
    Réponses: 5
    Dernier message: 12/12/2003, 00h50
  5. Temps de réponse entre deux sites
    Par coup dur dans le forum Décisions SGBD
    Réponses: 6
    Dernier message: 16/10/2003, 15h26

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