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 :

systeme de pagination [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Nouveau membre du Club
    Inscrit en
    Décembre 2008
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 48
    Points : 32
    Points
    32
    Par défaut systeme de pagination
    j'ai fait deux pages : test.php et categorie.php

    j'ai fait dans la page test.php:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     <li>
        <a href='categorie.php?genre=Animation'>Animation</a>
     </li>
    et dans la page categorie.php j'ai met ce 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
    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
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
     
    <?php
     
    $genre = $_GET['genre'];
    mysql_connect("localhost", "root", "");
    mysql_select_db("cine");
     
     
     
     
     
     
    // On met dans une variable le nombre de messages qu'on veut par page
    $nombreDeMessagesParPage = 8; // Essayez de changer ce nombre pour voir :o)
    // On récupère le nombre total de messages
    $retour = mysql_query('SELECT COUNT(*) AS titre FROM films');
    $donnees = mysql_fetch_array($retour);$totalDesMessages = $donnees['genre'];
    // On calcule le nombre de pages à créer
    $nombreDePages  = ceil($totalDesMessages / $nombreDeMessagesParPage);
     
     
     
     
    if (isset($_GET['page']))
    {
            $page = $_GET['page']; // On récupère le numéro de la page indiqué dans l'adresse (livreor.php?page=4)
    }
    else // La variable n'existe pas, c'est la première fois qu'on charge la page
    {
            $page = 1; // On se met sur la page 1 (par défaut)
    }
     
    // On calcule le numéro du premier message qu'on prend pour le LIMIT de MySQL
    $premierMessageAafficher = ($page - 1) * $nombreDeMessagesParPage;
     
     
     
     
    $reponse = mysql_query("SELECT * FROM films WHERE genre LIKE '%$genre%' ORDER BY id DESC LIMIT 8")or die(mysql_error());
    while ($donnees = mysql_fetch_array($reponse) )
    {
     
     
            echo $donnees['titre'];
        }
     
     
    echo 'Page : ';
    for ($i = 1 ; $i <= $nombreDePages ; $i++)
     
    if ($i == $page) 
    {
        echo '<li class="page-courante">' . $i . '</li>'; 
    }
    else			
    {
        echo '<li><a href="categorie.php?page=' . $i . '">' . $i . '</a></li> ';
    }
     
     
    if ($page < $nombreDePages) 
    {
            echo '<li><a href="categorie.php?page=' . ($page + 1) . '">...Suivante</a></li>';
    }
        echo '</ul>';
     
    ?>
    le probleme c'est qu'il affiche seulement les 8 titres qui a le genre animation mais sans pagination;

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Bonjour,

    Pourrais-tu nous décrire ce que tu obtiens precisemment ?

  3. #3
    Nouveau membre du Club
    Inscrit en
    Décembre 2008
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 48
    Points : 32
    Points
    32
    Par défaut
    il y a bcp de titres, mais il affiche les 8 titres sans pagination,

    comme ça :

    titre1
    titre2
    titre3

    page:

    et rien devant page :

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    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
     
     
    mysql_connect("localhost", "root", "");
    mysql_select_db("cine");
     
    $genre = mysql_real_escape_string($_GET['genre']);
     
    // On met dans une variable le nombre de messages qu'on veut par page
    $nombreDeMessagesParPage = 8; // Essayez de changer ce nombre pour voir :o)
    // On récupère le nombre total de messages
    $sql = "SELECT COUNT(*) AS titre FROM films WHERE genre LIKE '" . 
    $genre . "'";
    $retour = mysql_query($sql);
    $donnees = mysql_fetch_array($retour);
    $totalDesMessages = $donnees['titre'];
    Prends l'habitude de develloper en affichant toutes les erreurs, tu aurais vu que $donnees['genre'] n'existait pas.

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

Discussions similaires

  1. [MySQL] Système de pagination avec php/mysql
    Par carinelog dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 01/07/2013, 18h34
  2. [MySQL] systeme de pagination
    Par black-hat dans le forum PHP & Base de données
    Réponses: 0
    Dernier message: 29/07/2012, 00h19
  3. systeme de pagination
    Par bellak dans le forum Silverlight
    Réponses: 1
    Dernier message: 22/02/2009, 02h09
  4. [MySQL] resumer un systeme de pagination
    Par kayne dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 14/01/2009, 10h28

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