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 :

Requête très volumineuse - timeout !


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    82
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 82
    Par défaut Requête très volumineuse - timeout !
    Bonjour à tous,

    J'avais initialement posté dans la rubrique AJAX, car je pensais que le pb venait de là...
    Mais en fait, en testant sur une simple page php sans appel AJAX, j'obtiens également, au bout de 75 secondes environ, une page blanche (pas d'erreur, mais time out je suppose) en guise de résultat du traitement PHP/MySQL de mes qq 60000 enregistrements ! Et là je suis mal car je ne sais pas comment améliorer ce traitement.

    Donc :
    Le résultat de mon script donne une liste structurée (avec arborescence sur 3 niveaux : catégories/sous-catégories/sous-sous-catégories) de mes enregistrements que j'explose via des boucles While successives :

    -> CatégorieA
    -> Sous-catégorie1 (appartenant à CatégorieA)
    -> Sous-sous-catégorieA (appartenant à Sous-catégorie1)
    -> Enregistrement1 (appartenant à Sous-sous-catégorieA)
    -> Enregistrement2 (appartenant à Sous-sous-catégorieA)
    -> Enregistrement3 (appartenant à Sous-sous-catégorieA)
    ...etc.
    -> Sous-sous-catégorieB (appartenant à Sous-catégorie1)
    -> Enregistrement4 (appartenant à Sous-sous-catégorieB)
    -> Enregistrement5 (appartenant à Sous-sous-catégorieB)
    -> Enregistrement6 (appartenant à Sous-sous-catégorieB)
    ...etc.
    ...etc.
    -> Sous-catégorie2 (appartenant à CatégorieA)
    -> Sous-sous-catégorieC (appartenant à Sous-catégorie2)
    -> Enregistrement7 (appartenant à Sous-sous-catégorieC)
    -> Enregistrement8 (appartenant à Sous-sous-catégorieC)
    -> Enregistrement9 (appartenant à Sous-sous-catégorieC)
    ...etc.
    -> Sous-sous-catégorieD (appartenant à Sous-catégorie2)
    -> Enregistrement10 (appartenant à Sous-sous-catégorieD)
    -> Enregistrement11 (appartenant à Sous-sous-catégorieD)
    -> Enregistrement12 (appartenant à Sous-sous-catégorieD)
    ...etc.
    ...etc.
    ...etc.
    -> CatégorieB
    -> Sous-catégorie3 (appartenant à CatégorieB)
    -> Sous-sous-catégorieE (appartenant à Sous-catégorie3)
    -> Enregistrement13 (appartenant à Sous-sous-catégorieE)
    -> Enregistrement14 (appartenant à Sous-sous-catégorieE)
    -> Enregistrement15 (appartenant à Sous-sous-catégorieE)
    ...etc.
    -> Sous-sous-catégorieF (appartenant à Sous-catégorie3)
    -> Enregistrement16 (appartenant à Sous-sous-catégorieF)
    -> Enregistrement17 (appartenant à Sous-sous-catégorieF)
    -> Enregistrement18 (appartenant à Sous-sous-catégorieF)
    ...etc.
    ...etc.
    -> Sous-catégorie4 (appartenant à CatégorieB)
    -> Sous-sous-catégorieG (appartenant à Sous-catégorie4)
    -> Enregistrement19 (appartenant à Sous-sous-catégorieG)
    -> Enregistrement20 (appartenant à Sous-sous-catégorieG)
    -> Enregistrement21 (appartenant à Sous-sous-catégorieG)
    ...etc.
    -> Sous-sous-catégorieH (appartenant à Sous-catégorie4)
    -> Enregistrement22 (appartenant à Sous-sous-catégorieH)
    -> Enregistrement23 (appartenant à Sous-sous-catégorieH)
    -> Enregistrement24 (appartenant à Sous-sous-catégorieH)
    ...etc.
    ...etc.
    ...etc.
    ...etc.

    Sachant qu'il y a 7 catégories, comprenant chacune env. 9 sous-catégories, lesquelles comprenant chacune env. 12 sous-sous-catégories, lesquelles comprenant chacune env. 80 enregistrements
    On obtient donc mes 7 x 9 x 12 x 80 = env. 60000 enregistrements dans ma BDD.

    En PHP ça donne ça, en version simplifiée :
    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
     
    $req1 = "SELECT id_categorie, numero_categorie, nom_categorie FROM table_categories ORDER BY numero_categorie ASC";
    $res1 = mysql_query($req1) or die(mysql_error());
    echo '<ul id="niveau1">';
    while ($enr1 = mysql_fetch_array($res1)) {
        $IDCATEG = $enr1['id_categorie'];
        $CATEG = $enr1['numero_categorie']." - ".$enr1['nom_categorie'];
        echo '<li>'.$CATEG.
                '<ul id="niveau2">';
        $req2 = "SELECT id_sous_categorie, numero_sous_categorie, nom_sous_categorie FROM table_sous_categories WHERE id_categorie LIKE ".$IDCATEG." ORDER BY numero_sous_categorie ASC";
        $res2 = mysql_query($req2) or die(mysql_error());
        while ($enr2 = mysql_fetch_array($res2)) {
            $IDSOUSCATEG = $enr2['id_sous_categorie'];
            $SOUSCATEG = $enr2['numero_sous_categorie']." - ".$enr2['nom_sous_categorie'];
            echo '<li>'.$SOUSCATEG.
                    '<ul id="niveau3">';
            $req3 = "SELECT id_sous_sous_categorie, numero_sous_sous_categorie, nom_sous_sous_categorie FROM table_sous_sous_categories WHERE id_sous_categorie LIKE ".$IDSOUSCATEG." ORDER BY numero_sous_sous_categorie ASC";
            $res3 = mysql_query($req3) or die(mysql_error());
            while ($enr3 = mysql_fetch_array($res3)) {
                $IDSOUSSOUSCATEG = $enr3['id_sous_categorie'];
                $SOUSSOUSCATEG = $enr3['numero_sous_sous_categorie']." - ".$enr3['nom_sous_sous_categorie'];
                echo '<li>'.$SOUSSOUSCATEG.
                    '<ul id="listage">';
                $req4 = "SELECT champ1, champ2, champ3 FROM ma_table WHERE id_sous_sous_categorie LIKE ".$IDSOUSSOUSCATEG." ORDER BY champ1 ASC";
                $res4 = mysql_query($req4) or die(mysql_error());
                while ($enr4 = mysql_fetch_array($res4)) {
                    $CHAMP1= $enr4['champ1'];
                    $CHAMP2= $enr4['champ2'];
                    $CHAMP3= $enr4['champ3'];
                    echo '<li>'.$CHAMP1.' - '.$CHAMP2.' - '.$CHAMP3.'</li>';
                }
                mysql_free_result($res4);
                echo '</ul></li>';
            }
            mysql_free_result($res3);
            echo '</ul></li>';
        }
        mysql_free_result($res2);
        echo '</ul></li>';
    }
    mysql_free_result($res1);
    echo '</ul>';
    J'ai donc 4 boucles While imbriquées qui parcourent chacune des milliers d'enregistrements, ça fait lourdingue !
    Le site est hébergé chez 1and1, et apparemment on a la main sur pas mal de paramétrages via php.ini. Donc j'ai ajouté dans ce php.ini les paramètres suivants :
    memory_limit=-1
    max_execution_time=600
    mysql.connect_timeout=600
    Mais ça coince toujours !
    J'ai aussi pris soin de mettre des clés primaires sur mes id uniques de champs, et des index sur les clés étrangères dans mes différentes tables.

    Je suis perplexe...

    Et je vous le dis tout de suite : oui, il est nécessaire de pouvoir afficher l'intégralité de ces enregistrements, même si ça vous paraît saugrenu, et même si la plupart du temps l'utilisateur applique un filtre (par catégorie ou sous-catégorie) - d'ailleurs lorsqu'un tel filtre est appliqué à la requête, elle fonctionne parfaitement, ça prend qd même une vingtaine de secondes mais pas de pb de timeout car cela concerne au maximum 10000 enregistrements.)

    Le pire c'est que, il y a qq années, j'avais réalisé la même appli mais sous Access 97 et Visual Basic, avec les mêmes structures de requêtes, et ça tournait super bien avec le même volume d'enregistrements, alors je l'ai un peu mauvaise de constater que Access 97/VB serait plus puissant que mon couple préféré PHP/MySQL !!!
    Où alors j'ai raté un truc d'optimisation ou de paramétrage...

    Merci d'avance si vous avez des idées !

  2. #2
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Octobre 2006
    Messages
    108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Octobre 2006
    Messages : 108
    Par défaut Proposition
    Bonjour,

    Essai de mettre ceci en haut de ta page PHP en question.
    Sinon dans PHP.ini
    Perso j'avais un soucis de time OUT et les deux proposition mon débloqué.

    Bon courage.

  3. #3
    Membre chevronné

    Homme Profil pro
    Chomeur
    Inscrit en
    Juin 2006
    Messages
    347
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Chomeur

    Informations forums :
    Inscription : Juin 2006
    Messages : 347
    Par défaut
    Bonjour,

    C'est juste une suggestion, je ne suis pas trop sur que ça soit plus efficace, mais as tu essayé de limiter le nombre de requêtes? La si mon compte est bon, il y a 756 requêtes. Il est possible d'en faire une seule qui renverrai tous les enregistrements ou peut être 4 (en gros "select *" sur chacune des tables categories, ss-cat, etc) puis boucler dans chaque avec un test d'égalité d'Id?

    Bon courage...

Discussions similaires

  1. [AJAX] AJAX et requête MySQL très volumineuse
    Par Marmotton76 dans le forum AJAX
    Réponses: 8
    Dernier message: 05/02/2014, 15h07
  2. export de base très volumineuse
    Par slausseur dans le forum Administration
    Réponses: 17
    Dernier message: 12/04/2007, 11h40
  3. Optimisation d'une requête très lourde
    Par Benji76 dans le forum Requêtes
    Réponses: 9
    Dernier message: 24/02/2007, 11h35
  4. v.2003- Requête très spéciale..
    Par guyCnet dans le forum Access
    Réponses: 4
    Dernier message: 04/12/2006, 09h25
  5. Réponses: 4
    Dernier message: 09/12/2005, 08h25

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