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 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155
|
<?php
/**
*class qui va permettre de faire le lien entre la BDD et la categorie
**/
class CategorieManager
{
/**
* Attribut contenant l'instance représentant la BDD
* @type PDO
*/
private $db;
/**
* Constructeur étant chargé d'enregistrer l'instance de PDO dans l'attribut $db
**/
public function __construct($db)
{
$this->db = $db;
}
/**
* Méthode permettant d'ajouter une categorie
* @param $categorie Categorie La categorie à ajouter
* @return vide
*/
protected function add(Categorie $categorie)
{
$requete = $this->db->prepare('INSERT INTO categorie SET titre = :titre, description = :description,estActive = :estActive, estDansMenu = :estDansMenu,dateModification = :dateModification, dateCreation = :dateCreation,idSupCategorie = :idSupCategorie');
$requete->bindValue(':titre', $categorie->titre());
$requete->bindValue(':description', $categorie->description());
$requete->bindValue(':estActive', $categorie->estActive());
$requete->bindValue(':estDansMenu', $categorie->estDansMenu());
$requete->bindValue(':dateModification', $categorie->dateModification());
$requete->bindValue(':dateCreation', $categorie->dateCreation());
$requete->bindValue(':idSupCategorie', $categorie->idSupCategorie());
$requete->execute();
}
/**
* Méthode renvoyant le nombre de categorie total
* @return int
*/
public function count()
{
return $this->db->query('SELECT COUNT(*) FROM categorie')->fetchColumn();
}
/**
* Méthode permettant de supprimer une categorie
* @param $id int L'identifiant de la categorie à supprimer
* @return vide
*/
public function delete($id)
{
$requete = $this->db->prepare('DELETE FROM categorie WHERE id = :id');
$requete->bindValue(':id', $id, PDO::PARAM_INT);
$requete->execute();
}
/**
* Méthode retournant une liste de categorie demandée
* @param $debut int La première categorie à sélectionner
* @param $limite int Le nombre de categorie à sélectionner
* @return array La liste des categorie. Chaque categorie entrée est une instance de categorie.
*/
public function getList($debut = -1, $limite = -1)
{
$listeCategorie = array();
$sql = 'SELECT id ,titre ,description ,estActive ,estDansMenu ,DATE_FORMAT (dateModification, \'le %d/%m/%Y à %Hh%i\') as dateModification, DATE_FORMAT (dateCreation, \'le %d/%m/%Y à %Hh%i\') AS dateCreation ,idSupCategorie FROM categorie ORDER BY id DESC';
if ($debut != -1 || $limite != -1)
$sql .= ' LIMIT ' . (int) $debut . ', ' . (int) $limite;
$requete = $this->db->query($sql);
while ($categorie = $requete->fetch(PDO::FETCH_ASSOC))
$listeCategorie[] = new Categorie ($categorie);
$requete->closeCursor();
return $listeCategorie;
}
/**
* Méthode retournant une categorie précise
* @param $id int L'identifiant de la categorie à récupérer
* @return Categorie La categorie demandée
*/
public function getUnique($id)
{
$requete = $this->db->prepare('SELECT id ,titre ,description ,estActive ,estDansMenu ,DATE_FORMAT (dateModification, \'le %d/%m/%Y à %Hh%i\') as dateModification, DATE_FORMAT (dateCreation, \'le %d/%m/%Y à %Hh%i\') AS dateCreation ,idSupCategorie FROM categorie WHERE id = ?');
$requete->bindValue(':id', (int) $id, PDO::PARAM_INT);
$requete->execute();
return new Categorie($requete->fetch(PDO::FETCH_ASSOC));
}
/**
* Méthode permettant d'enregistrer une categorie
* @param $Categorie Categorie la categorie à enregistrer
* @voir function add()
* @voir fonction modify()
* @return vide
*/
public function save(Categorie $categorie)
{
if ($categorie->isValid())
{
$categorie->isCategorie() ? $this->add($categorie) : $this->update($categorie);
}
else
{
throw new RuntimeException('La categorie doit être valide pour être enregistrée');
}
}
/**
* Méthode permettant de modifier une categorie
* @param $categorie categorie la categorie à modifier
* @return vide
*/
protected function update(Categorie $Categorie)
{
$requete = $this->db->prepare('UPDATE categorie SET titre = :titre, description = :description ,estActive = :estActive, estDansMenu = :estDansMenu,dateModification = NOW(),idSupCategorie = :idSupCategorie WHERE id = :id');
$requete->bindValue(':titre', $Categorie->titre());
$requete->bindValue(':description', $Categorie->description());
$requete->bindValue(':estActive', $Categorie->estActive());
$requete->bindValue(':estDansMenu', $Categorie->estDansMenu());
$requete->bindValue(':dateModification', $Categorie->dateModification());
$requete->bindValue(':idSupCategorie', $Categorie->idSupCategorie());
$requete->bindValue(':id', $Categorie->id(), PDO::PARAM_INT);
$requete->execute();
}
}
?> |
Partager