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 :

Système de pagination PHP5 [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 54
    Par défaut Système de pagination PHP5
    Bonsoir à tous j'aimerai effectuer un système de pagination c'est-à-dire une nouveauté par page le problème c'est que je ne vois pas du tout comment faire car, j'ai une boucle foreach. Voila mon code sans le système de pagination. Merci d'avance pour votre aide.

    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
    68
    69
    70
    71
    72
    73
    74
    75
     
    <?php 
     
    session_start(); 
    require_once("class_Nouveaute.php");
    require_once("connexion.php");
     
    	$Nouveaute=unserialize($_SESSION['nouv']);
     
    ?>
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
     
    <head>
     
    <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
    <link rel="stylesheet" media="screen" type="text/css" href="design.css" />
    <title>Association Philatélique de la Région Clermontoise</title>
     
    </head>
     
    <body>
     
    	<div id="header">
       	</div>
     
    	<div id="menu">
     
    		<SCRIPT LANGUAGE="JavaScript" SRC="ejs_menu_dyn.js"></SCRIPT>
     
    	</div>
     
    	<div id="corps">
     
    	<br/>
     
    		<?php
     
    				$listNouv=$Nouveaute->getNouv();
     
    				foreach ($listNouv as $Nouv)
    				{
    					echo '<font face=\'Comic Sans MS\', \'Trebuchet MS\', Georgia" color="silver" size="5"><b><ins><center>'; echo $Nouv->getNomNouv(); echo '</center></ins></b></font>';
    					echo '<br/>';
    				echo '<font face=\'Comic Sans MS\', \'Trebuchet MS\', Georgia" color="white" size="2"><b>Date de Sortie : </b>'; echo $Nouv->getDateSortie(); 
    				echo '<br/>';
    				echo '<b>Format : </b>'; echo $Nouv->getFormat();
    				echo '<br/>';
    				echo '<b>Création : </b>'; echo $Nouv->getCreation();
    				echo '<br/>';
    				echo '<b>Mise en page : </b>'; echo $Nouv->getMiseEnPage();
    				echo '<br/>';
    				echo '<b>Impression : </b>'; echo $Nouv->getImpression();
    				echo '<br/>';
    				echo '<b>Usage : </b>'; echo $Nouv->getUsage();
    				echo '<br/><br/>';
    				echo '<p>'; echo $Nouv->getDescription(); echo '</p></font>';
    				echo '<br/><br>';
    				echo '<center><img src="img/'; echo $Nouv->getImage(); echo '"/></center>';
    				echo '<br/><br/>';
    				}
     
    		?>
     
    	</div>
     
    	<div id="footer">
     
    	</div>
     
     
    </body>
     
    </html>

  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
    Par défaut
    un système de pagination c'est-à-dire une nouveauté par page
    Pourrais-tu expliciter ça ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 54
    Par défaut
    En fait mon foreach affiche toutes les nouveautés (titre, date) présente dans ma base de données sauf qu'il l'est mets toutes sur la même page donc je voudrai avoir par exemple <précédente|1|2|....|suivante> où sur chaque page je n'aurai qu'une nouveauté

  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
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 54
    Par défaut
    Je l'avez déjà regarder ce qui me pose problème c'est de l'implémenter dans mon code à cause de ma boucle foreach

  6. #6
    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
    Par défaut
    En quoi cela te gêne ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 54
    Par défaut
    Parce que si j'ai bien compris il faudrait que je l'implémente dans le foreach mais le problème c'est que tout va se réitérer à chaque donc ça marchera pas j'ai déjà essayer et je n'ai pas eu du tout le résultat que j'attendais.

  8. #8
    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
    Par défaut
    Que fais ta methode getnouv() ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  9. #9
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 54
    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
     
    public function getNouv()
    	{
    		$requete="SELECT * FROM nouveaute ORDER BY dateSortie DESC";
    		$resultat = mysql_query($requete);
    		while($donnees=mysql_fetch_array($resultat))
    		{
    			$numNouv=$donnees['numNouv'];
    			$nomNouv=$donnees['nomNouv'];
    			$dateSortie=$donnees['dateSortie'];
    			$format=$donnees['format'];
    			$creation=$donnees['creation'];
    			$miseEnPage=$donnees['miseEnPage'];
    			$impression=$donnees['impression'];
    			$usage=$donnees['usage'];
    			$description=$donnees['description'];
    			$image=$donnees['image'];
     
    			$listNouv[]= new Nouveaute($numNouv, $nomNouv, $dateSortie, $format, $creation, $miseEnPage, $impression, $usage, $description,$image);
     
    		}
     
    	return $listNouv;
    }
    Alors en faite elle me renvoie la liste des nouveautés

  10. #10
    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
    Par défaut
    Tu as juste a lui passer les deux bornes de LIMIT en argument.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  11. #11
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 54
    Par défaut
    Donc j'implémente le code de pagination dans cette méthode selon toi?

  12. #12
    Membre éprouvé Avatar de LeXo
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    1 147
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 147
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT * FROM table
    LIMIT A OFFSET B
    A ton nombre d'enregistrement
    B ton offset

  13. #13
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 54
    Par défaut
    Un petit problème subsiste en effet ceci marche mais me renvoie une erreur et je ne sais pas comment faire pour l'enlever voici le code de ma requête

    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
     
    public function getNouv($premiereEntree,$messagesParPage)
    	{
    		$requete="SELECT * FROM nouveaute ORDER BY dateSortie DESC LIMIT $premiereEntree, $messagesParPage";
    		$resultat = mysql_query($requete)or die("Erreur SQL : $query<br/>".mysql_error());
    		while($donnees=mysql_fetch_array($resultat))
    		{
    			$numNouv=$donnees['numNouv'];
    			$nomNouv=$donnees['nomNouv'];
    			$dateSortie=$donnees['dateSortie'];
    			$format=$donnees['format'];
    			$creation=$donnees['creation'];
    			$miseEnPage=$donnees['miseEnPage'];
    			$impression=$donnees['impression'];
    			$usage=$donnees['usage'];
    			$description=$donnees['description'];
    			$image=$donnees['image'];
     
    			$listNouv[]= new Nouveaute($numNouv, $nomNouv, $dateSortie, $format, $creation, $miseEnPage, $impression, $usage, $description,$image);
     
    		}
     
    	return $listNouv;
    }
    et voici l'erreur :


    Notice: Undefined variable: query in C:\Program Files\EasyPHP 2.0b1\www\SiteAPRC\APRC\class_Nouveaute.php on line 56
    Erreur SQL :
    Erreur de syntaxe près de '-1, 1' à la ligne 1

  14. #14
    Membre éprouvé Avatar de LeXo
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    1 147
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Janvier 2004
    Messages : 1 147
    Par défaut
    c'est quoi ce -1 ??

    affiche ta requete tu comprendras d'ou vient ton problème.

  15. #15
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 54
    Par défaut
    Ben c ca que je comprend pas je pense que c'est mes limites mais ceci devrait faire zéro pourtant l'autre code est bon

    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
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
     
    <?php 
     
    session_start(); 
    require_once("class_Nouveaute.php");
    require_once("connexion.php");
     
    	$Nouveaute=unserialize($_SESSION['nouv']);
     
    ?>
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
     
    <head>
     
    <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
    <link rel="stylesheet" media="screen" type="text/css" href="design.css" />
    <title>Association Philatélique de la Région Clermontoise</title>
     
    </head>
     
    <body>
     
    	<div id="header">
       	</div>
     
    	<div id="menu">
     
    		<SCRIPT LANGUAGE="JavaScript" SRC="ejs_menu_dyn.js"></SCRIPT>
     
    	</div>
     
    	<div id="corps">
     
    	<br/>
     
    		<?php
     
    				$messagesParPage=1;//nombre de messages par page que l'on souhaite
    				$total=$Nouveaute->compter();//appel de la méthode permettant de compter le nombre d'enregistrement dans la table 					nouveaute					
    				$nombreDePages=ceil($total/$messagesParPage);//Compte le nombre de pages
     
    				if(isset($_GET['page'])) // Si la variable $_GET['page'] existe...
    				{
         				$pageActuelle=intval($_GET['page']);
     
         				if($pageActuelle>$nombreDePages) // Si la valeur de $pageActuelle (le numéro de la page) est plus grande que 				$nombreDePages...
        				 {
             				 $pageActuelle=$nombreDePages;
         				 }
    				}
    				else // Sinon
    				{
         				$pageActuelle=1; // La page actuelle est la n°1    
    				}
     
    				$premiereEntree=($pageActuelle-1)*$messagesParPage; // On calcul la première entrée à lire
     
    				$listNouv=$Nouveaute->getNouv($premiereEntree,$messagesParPage);
     
    				foreach ($listNouv as $Nouv)
    				{
    					echo '<font face=\'Comic Sans MS\', \'Trebuchet MS\', Georgia" color="silver" size="5"><b><ins><center>'; echo $Nouv->getNomNouv(); echo '</center></ins></b></font>';
    					echo '<br/>';
    				echo '<font face=\'Comic Sans MS\', \'Trebuchet MS\', Georgia" color="white" size="2"><b>Date de Sortie : </b>'; echo $Nouv->getDateSortie(); 
    				echo '<br/>';
    				echo '<b>Format : </b>'; echo $Nouv->getFormat();
    				echo '<br/>';
    				echo '<b>Création : </b>'; echo $Nouv->getCreation();
    				echo '<br/>';
    				echo '<b>Mise en page : </b>'; echo $Nouv->getMiseEnPage();
    				echo '<br/>';
    				echo '<b>Impression : </b>'; echo $Nouv->getImpression();
    				echo '<br/>';
    				echo '<b>Usage : </b>'; echo $Nouv->getUsage();
    				echo '<br/><br/>';
    				echo '<p>'; echo $Nouv->getDescription(); echo '</p></font>';
    				echo '<br/><br>';
    				echo '<center><img src="img/'; echo $Nouv->getImage(); echo '"/></center>';
    				echo '<br/><br/>';
    				}
     
    				echo '<p><center>'; //Pour l'affichage, on centre la liste des pages
    				for($i=1; $i<=$nombreDePages; $i++) //On fait notre boucle
    				{
         			//On va faire notre condition
        			 	if($i==$pageActuelle) //Si il s'agit de la page actuelle...
         				{
            				 echo ' [ '.$i.' ] '; 
        				}	
         				else //Sinon...
         				{
              				echo ' <a href="affNouveautes.php?page='.$i.'">'.$i.'</a> ';
         				}
    				}
    				echo '</center></p>';
     
    		?>
     
    	</div>
     
    	<div id="footer">
     
    	</div>
     
     
    </body>
     
    </html>

  16. #16
    Membre averti
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    54
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 54
    Par défaut
    Merci pour votre aide ça marche

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

Discussions similaires

  1. [Système] Système de pagination
    Par innova dans le forum Langage
    Réponses: 1
    Dernier message: 25/09/2006, 15h08
  2. [Smarty] Ecriture d'un système de pagination
    Par wkd dans le forum Bibliothèques et frameworks
    Réponses: 6
    Dernier message: 20/09/2006, 11h01
  3. [MySQL] Système de pagination pour une galerie photo
    Par Badaboumpanpan dans le forum PHP & Base de données
    Réponses: 10
    Dernier message: 27/06/2006, 15h31
  4. [Système] pointeurs dans php5
    Par haffouff dans le forum Langage
    Réponses: 11
    Dernier message: 21/04/2006, 13h02
  5. [phpBB][2] Réalisation d'un système de pagination
    Par AlphonseBrown dans le forum Bibliothèques et frameworks
    Réponses: 8
    Dernier message: 26/10/2005, 11h26

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