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 :

Demande d'aide pour mon PFE


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Inscrit en
    Février 2011
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Février 2011
    Messages : 10
    Points : 5
    Points
    5
    Par défaut Demande d'aide pour mon PFE
    Bonjour

    Je voudrais trouver une solution pour n'afficher que 12 articles dans la page index de chaque categories et le reste sera afficher dans la page 2,3,4... selon le nombre d'article insérés dans la base données

    je vous passe le code en piece jointe
    c'est la page index en php
    Fichiers attachés Fichiers attachés

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059

  3. #3
    Expert éminent
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Points : 7 762
    Points
    7 762
    Par défaut
    Si tu connais la POO et PDO, tu peux utiliser cette classe pour itérer des jeux de résultat mysql:
    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
     
    <?php
    /**
     * PHP AXIOM
     *
     * @license GPL
     * @author Benjamin DELESPIERE <benjamin.delespierre@gmail.com>
     * @category libAxiom
     * @package libraries
     * @version %version%
     */
     
    /**
     * PDO Statement Iterator Class
     *
     * @author Delespierre
     * @version 1.0.0
     * @subpackage PDOStatementIterator
     */
    class PDOStatementIterator extends IteratorIterator implements SeekableIterator, Countable {
     
        /**
         * Internal statement reference
         * @internal
         * @var PDOStatement
         */
        protected $_statement;
     
        /**
         * Internal counter
         * @internal
         * @var integer
         */
        protected $_count;
     
        /**
         * Default constructor
         * @param PDOStatement $statement
         */
        public function __construct (PDOStatement $statement) {
            parent::__construct($this->_statement = $statement);
        }
     
        /**
         * (non-PHPdoc)
         * @see SeekableIterator::seek()
         */
        public function seek ($position) {
            if ($position > $this->count())
                throw new OutOfBoundsException("Cannot seek to $position");
     
            if ($position < $this->key())
                throw new OutOfRangeException("Cannot seek to $position");
     
            for ($i = $this->key(); $i < $position; $i++)
                $this->next();
        }
     
        /**
         * (non-PHPdoc)
         * @see Countable::count()
         */
        public function count () {
            if (!isset($this->_count))
    		    return $this->_count = $this->_statement->rowCount();
    	    return $this->_count;
        }
    }
    Pour l'utiliser:
    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
     
    class Articles {
     
        //.....
        public static function getArticles ($search_params = array()) {
            $query = "SELECT * FROM `blog`.`articles`";
     
            if (!empty($search_params)) {
                $pieces = array();
                foreach ($search_params as $key => $value)
                    $pieces[] = "`$key`=:$key";
                $query .= " WHERE " . implode(' AND ', $pieces);
            }
     
            $stmt = Database::prepare($query);
            if ($stmt->execute(array_keys_prefix($search_params, ':'))) {
                $article = new self;
                $stmt->setFetchMode(PDO::FETCH_INTO, $article);
                return new PDOStatementIterator($stmt);
            }
            return false;
        }
    }
    Ensuite, pour la pagination à proprement parler, tu peux utiliser le LimitIterator de cette façon:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $articles = Article::getArticles();
    $articles = new LimitIterator($articles, $from, $to);
    où $from et $to sont tes paramètres de pagination.

Discussions similaires

  1. Besoin d'aide pour mon PFE, s'il vous plait
    Par mouss2522 dans le forum Sujets
    Réponses: 1
    Dernier message: 11/04/2011, 22h11
  2. Aide pour mon PFE
    Par Nikes dans le forum Macros et VBA Excel
    Réponses: 16
    Dernier message: 20/08/2009, 01h15
  3. Demande d'aide pour mon premier programme
    Par ne2sbeal dans le forum Windows Forms
    Réponses: 6
    Dernier message: 21/01/2009, 21h53
  4. AIDE pour mon PFE : Local IDS en c#
    Par sadokc dans le forum C#
    Réponses: 1
    Dernier message: 20/05/2007, 14h04

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