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 :

pagination à partir d'une requete (limit, between) [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
    Homme Profil pro
    Auditeur informatique
    Inscrit en
    Septembre 2017
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Auditeur informatique

    Informations forums :
    Inscription : Septembre 2017
    Messages : 22
    Par défaut pagination à partir d'une requete (limit, between)
    Bonjour,

    J'essaye de paginer des résultats de requête php/mysql. J'y arrivais jusque là mais je dispose cette fois d'une table de près de 10000 enregistrements avec plus de 6 jointures...
    J'utilisais jusque là la méthode qui consiste à découper les résultats par tranches avec la clause LIMIT. Avec cette méthode ma requête actuelle peut mettre jusqu'à 30 secondes avant de descendre des résultats ! C'est parait il le mal endémique des forums qui ont du succès ! (mon site en construction n'est pas un forum )

    J'ai lu un article (trop) rapide sur la clause BETWEEN avec un curseur... qui serait moins gourmande en ressources. J

    Quelqu'un en saurait-il un peu plus ?

    merci de votre aide

  2. #2
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Salut,

    il faut déjà regarder le temps que met ta requête à s'exécuter sans la clause LIMIT.
    Bon, 10 000 enregistrements c'est instantané même avec 6 jointures. Si ce n'est pas le cas, c'est que tu as un problème d'index.

  3. #3
    Membre éclairé Avatar de solo190
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Avril 2007
    Messages
    412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 412
    Par défaut
    Bonjour à tous ,
    dans la meme lancée que rawsrc , il faut te rassurer que tu as bien des clés primaires ,secondaire et des index sur tes tables
    Evite aussi de faire des sous-requettes car elle consomme plus de ressource
    Au besoin tu peux resenter ta requette
    A+

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Peut-on voir la requête en question ? et accessoirement le bout de code qui l'utilise ?
    ça peut être une bonne idée de tester la requête avec et sans limit directement sur la base (via PhpMyAdmin ou équivalent) pour vérifier si c'est bien la requête qui est lente et pas le traitement des données.
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Membre averti
    Homme Profil pro
    Auditeur informatique
    Inscrit en
    Septembre 2017
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Auditeur informatique

    Informations forums :
    Inscription : Septembre 2017
    Messages : 22
    Par défaut Pagination à partird'une requête (limit, between)
    Merci pour vos messages !

    J'ai donc vérifié les index et effectivement il en manquait sur deux tables. En fait aucune table n'avait d'index mais des clés primaires (sauf deux tables donc). Je pensais que la clé primaire avait valeur d'index. J'ai donc rajouté un index sur chaque table en plus de la clé primaire.

    Du coup la vitesse s'est considérablement améliorée. Je suis toujours en local, j'espère que cette requête sera aussi rapide sur le site hébergé !
    J'essaye d'optimiser encore...

    Encore merci pour votre aide. Je pensais le problème insoluble. J'ai lu sur le Web un article qui explique que cette méthode (découpage par la clause limit) était vouée à l'échec sur des grosse requêtes et qu'il fallait se tourner vers l'utilisation d'un curseur et de la clause Between...

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 09/02/2017, 23h32
  2. supprimer un enregistrement a partir d'une requete
    Par tooneygirl dans le forum Access
    Réponses: 3
    Dernier message: 20/06/2005, 15h26
  3. Réponses: 6
    Dernier message: 19/11/2004, 16h52
  4. Tableau a partir d'une requete sql
    Par 10-nice dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 25/10/2004, 16h37
  5. [TQuery]Réaliser une requete à partir d'une requete
    Par Eric SAULNIER dans le forum Bases de données
    Réponses: 2
    Dernier message: 09/07/2004, 12h00

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