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 :

Affichage page par page PHP MySQL [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Femme Profil pro
    Etudiante
    Inscrit en
    Avril 2011
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Etudiante

    Informations forums :
    Inscription : Avril 2011
    Messages : 16
    Par défaut Affichage page par page PHP MySQL
    Bonjour,
    Je suis entrain de créer un logiciel de gestion de centre de formation avec php4 et MySql.
    quand le responsable veut consulter la liste des formations, on veut que 10 formations s'affichent par page et en cliquant sur un bouton suivant 10 autres formations s'affichent, malhereusement j'arrive pas a faire cette procédure (toutes les formations s'affichent em méme temps).
    voila mon code:
    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
    <?php
     
     
     
     
    $result=mysql_query("select * from theme");
    while($donnees=mysql_fetch_array($result))
    {
     
     
    echo"<tr>";
    echo "<td>".$donnees['code_th']."</td>";
    echo "<td>".$donnees['libelle']."</td>";
    echo "<td>".$donnees['vh']."</td>";
    echo "<td>".$donnees['prix']."</td>";
    ?>
    Qui a une idée et peut m'aider SVP.
    Merci d'avance

  2. #2
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 322
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 322
    Billets dans le blog
    17
    Par défaut
    Mettons que le script affichant les formations s'appelle formations.php
    Mettons que tu veuilles afficher des pages de 10 formations
    Mettons que ce script accepte un argument GET page indiquant le n° de la page à afficher
    L'appel à la 1re page sera de la forme formations.php?page=1, à la 2nde page formations.php?page=2, etc.

    La requête ci-dessous extrait de ta BdD les 10 formations de la page appelée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $formationsParPage = 10 ;
    $offset = ($_GET['page'] - 1) * $formationsParPage ;
    $sql = 'SELECT ALL id, nom '
         . 'FROM formations '
         . 'ORDER BY nom ASC '
         . "LIMIT $offset, $formationsParPage" ;
    LIMIT = on extrait $formationsParPage formations à partir de la formation n° $offset.
    Doc MySQL sur LIMIT : http://dev.mysql.com/doc/refman/5.0/fr/select.html

    Pour générer le lien vers la page suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="formations.php?page=<?php echo $_GET['page'] + 1 ?>">Page suivante</a>
    Vers la page précédente :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="formations.php?page=<?php echo $_GET['page'] - 1 ?>">Page précédente</a>
    Voilà, le gros y est, t'as plus qu'à tester et peaufiner ;-)

  3. #3
    Membre actif
    Femme Profil pro
    Etudiante
    Inscrit en
    Avril 2011
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Etudiante

    Informations forums :
    Inscription : Avril 2011
    Messages : 16
    Par défaut
    Merci bien Séb,
    mais un erreur qui s'affiche dans cette ligne:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $offset = ($_GET['page'] - 1) * $formationsParPage ;
    l'erreur est le suivant:

    Notice: Undefined index: page in C:\Program Files\EasyPHP-5.3.3.1\www\bptc\liste_formation.php on line 89

  4. #4
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 322
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 322
    Billets dans le blog
    17
    Par défaut
    L'appel à la 1re page sera de la forme formations.php?page=1


    Peaufiner c'est aussi prendre en compte ce genre de situation.

  5. #5
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2011
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2011
    Messages : 36
    Par défaut
    Bonjour,

    J'ajouterais le fait de tester si le paramètre existe dans le cas où une personne arriverait sur la page sans avoir cliqué sur un lien, ou qu'un lien soit mal formé. ce qui donnerait :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    $formationsParPage = 10 ;
    $page = 1;
    // On test si la variable existe
    if (isset($_GET['page'])) {
         // On test si c'est un entier
         if(is_int($_GET['page'])) {
              $page = $_GET['page'];
         }
    }
    $offset = ($page - 1) * $formationsParPage ;
    $sql = 'SELECT ALL id, nom '
         . 'FROM formations '
         . 'ORDER BY nom ASC '
         . "LIMIT $offset, $formationsParPage" ;
    et donc le lien vers la page suivante donnerait ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="formations.php?page=<?php echo $page + 1 ?>">Page suivante</a>
    La page précédente :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="formations.php?page=<?php echo $page - 1 ?>">Page précédente</a>

  6. #6
    Membre actif
    Femme Profil pro
    Etudiante
    Inscrit en
    Avril 2011
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Etudiante

    Informations forums :
    Inscription : Avril 2011
    Messages : 16
    Par défaut
    Merci les gars tout est claire maitenant.
    Ca marche

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

Discussions similaires

  1. Affichage ipconfig /displaydns page par page? windows7
    Par destructive.flame dans le forum Windows
    Réponses: 1
    Dernier message: 28/02/2014, 08h00
  2. [MySQL] Affichage du résultat page par page (pagination)
    Par marcito dans le forum PHP & Base de données
    Réponses: 12
    Dernier message: 20/07/2007, 14h53
  3. [PHP-JS] Affichage page par page
    Par Attilius dans le forum Langage
    Réponses: 8
    Dernier message: 09/08/2006, 18h23
  4. [Tableaux] PB liens apres affichage page par page
    Par x2thez dans le forum Langage
    Réponses: 16
    Dernier message: 15/03/2006, 16h58
  5. [MySQL] afficher plusieurs enregistrements par page par page à la volée
    Par pod1978 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 14/03/2006, 12h22

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