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 :

Petit soucis de pagination [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Homme Profil pro
    Ingénieur réseau et sécurité / Consultant
    Inscrit en
    Août 2005
    Messages
    1 068
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ingénieur réseau et sécurité / Consultant
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 1 068
    Par défaut Petit soucis de pagination
    salut tout le monde ! voila j'ai un script pour faire de la pagination mais sa ne fonctionne pas parfaitement ... j'ai un problème lorsque je clique sur le numéro pour aller sur la page suivante... en faite le lien n'est pas bon...

    voici le 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
     
     
    <? 
    /* configuration */ 
    $user = "root";
    $pwd = "";
    $server = "localhost";
    mysql_connect($server,$user,$pwd);
    mysql_select_db("pagination");
       $table_fiche = "pagination" ; 
       $sql = "SELECT * from $table_fiche"; // requete qui sera envoyer pour recupere les resultats 
       $nbr_par = 5; // nombre d'enregistrement par page 
     
    /* on  compte le nombre d'enregistrement */ 
       $retour = mysql_query("SELECT COUNT(*) AS nbre_entrees FROM $table_fiche "); 
       $donnees = mysql_fetch_array($retour); 
       $nbr = $donnees['nbre_entrees']; 
     
    /* decoupage par page */ 
       $nombre_de_page = ceil($nbr/$nbr_par); 
    /* verifie si on a pas appelle de page */    
       if (isset ($_GET['page'])) 
       { 
       // recup le numero de la page a choper 
          $page = $_GET['page']; 
          $sql .= " LIMIT $page ; "; 
       // on affiche la page 
          $reponse = mysql_query($sql); // Requête SQL 
          while ($donnees = mysql_fetch_array($reponse) ) 
          { 
          echo $donnees['message']."<br>";  
          } 
       } 
       else // sa veut dire qu'il y'en a pas eu 
       { 
          $sql .= " LIMIT 0,$nbr_par ; "; 
          // on affiche la page 
          $reponse = mysql_query($sql); // Requête SQL 
          while ($donnees = mysql_fetch_array($reponse) ) 
          { 
          echo $donnees['message']."<br>"; 
          } 
       } 
     
    /* on affiche le menu qui permet de changer de page */ 
       $limit = 30 ; 
       for ( $i = 1 ; $i <= $nombre_de_page ; $i++ ) 
       { 
          if ( $i == 1 ) 
          { 
             $trans = "0,".$nbr_par ; 
          } 
          else 
          { 
             $limit2 = $limit + $nbr_par ; 
             $trans = $limit2.",".$nbr_par ; 
          } 
             echo "<a href=\"test.php?page=$trans\" >".$i."</a> - " ; 
          $limit = $limit + $nbr_par ; 
       } 
     
    ?>
    je desespere... je ne trouve vraiment pas l'erreur. merci de votre aide

  2. #2
    Expert confirmé Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Par défaut
    Citation Envoyé par cyrill
    en faite le lien n'est pas bon...
    Pourquoi ?

  3. #3
    Membre éprouvé
    Homme Profil pro
    Ingénieur réseau et sécurité / Consultant
    Inscrit en
    Août 2005
    Messages
    1 068
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ingénieur réseau et sécurité / Consultant
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 1 068
    Par défaut
    et bien la page 1 a ce lien : test.php?page=0,5 . 0 pour le numéro de page et 5 pour le nombre d'élément par page... le lien pour accèder a la page 2 devrai etre test.php?page=1,5 etc... mais la sa me met test.php?page=40,5 ...

  4. #4
    Expert confirmé Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Par défaut
    Ben voilà tu as ta réponse

    Dans ton algo :
    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
    $limit = 30 ; 
       for ( $i = 1 ; $i <= $nombre_de_page ; $i++ ) 
       { 
          if ( $i == 1 ) 
          { 
             $trans = "0,".$nbr_par ; 
          } 
          else 
          { 
             $limit2 = $limit + $nbr_par ; 
             $trans = $limit2.",".$nbr_par ; 
          } 
             echo "<a href=\"test.php?page=$trans\" >".$i."</a> - " ; 
          $limit = $limit + $nbr_par ; 
       }
    Si on execute :

    Code $i == 1 : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $trans = "0,".$nbr_par;  == "0,5"
    $limit = $limit + $nbr_par; == 30 + 5 == 35

    Code $i == 2 : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $limit2 = $limit + $nbr_par;  == 35 + 5 == 40
    $trans = $limit2.",".$nbr_par ; == 40.",".$nbr_par == 40,5
    ...

  5. #5
    Membre éprouvé
    Homme Profil pro
    Ingénieur réseau et sécurité / Consultant
    Inscrit en
    Août 2005
    Messages
    1 068
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ingénieur réseau et sécurité / Consultant
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 1 068
    Par défaut
    mais si =1 sa marche !!! lol c'est sa le plus louche

  6. #6
    Expert confirmé Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Par défaut
    ben tout simplement parce que tu as fait un cas particulier pour 1 !!!

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

Discussions similaires

  1. Petit soucis pour se connecter à l'adsl
    Par Blowih dans le forum Réseau
    Réponses: 4
    Dernier message: 28/07/2004, 00h16
  2. petit soucy de fenetre cmd
    Par FeetloveR666 dans le forum Windows
    Réponses: 5
    Dernier message: 03/07/2004, 14h24
  3. petit soucis lors d'un LOAD DATA INFILE
    Par Jovial dans le forum SQL Procédural
    Réponses: 9
    Dernier message: 04/06/2004, 11h58
  4. Réponses: 6
    Dernier message: 21/01/2004, 13h25
  5. [DEBUTANT] petits soucis avec un prgm de chat
    Par LechucK dans le forum MFC
    Réponses: 8
    Dernier message: 19/01/2004, 16h52

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