diff options
Diffstat (limited to 'src/model/DB.php')
-rw-r--r-- | src/model/DB.php | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/src/model/DB.php b/src/model/DB.php new file mode 100644 index 0000000..381623b --- /dev/null +++ b/src/model/DB.php | |||
@@ -0,0 +1,48 @@ | |||
1 | <?php | ||
2 | // php/DB.php | ||
3 | |||
4 | // cette classe suit le pattern "singleton" | ||
5 | // but: ne permettre qu'une seule instance de la classe (laquelle sera éventuellement globale) | ||
6 | |||
7 | // comment? | ||
8 | // - Un attribut privé et statique contiendra l'instance unique de la classe | ||
9 | // - Un constructeur privé afin d'empêcher l'instanciation depuis l'extérieur de la classe | ||
10 | // - Une méthode statique qui permet soit d'instancier la classe soit de retourner l'unique instance créée. | ||
11 | |||
12 | class DB extends PDO | ||
13 | { | ||
14 | // paramètres du constructeur de PDO (avec sqlite seul le premier est nécessaire) | ||
15 | public static $dsn = ''; // Data Source Name = 1er paramètre | ||
16 | //~ public static $dbms = 'sqlite'; | ||
17 | //~ public static $user = ''; | ||
18 | //~ public static $password = ''; | ||
19 | //~ public static $options = ''; | ||
20 | private static $Instance; | ||
21 | |||
22 | private function __construct() // exécuté une seul fois à cause du "if" dans getInstance() | ||
23 | { | ||
24 | try | ||
25 | { | ||
26 | parent::__construct(self::$dsn); // => PDO::$dsn | ||
27 | //$this->setAttribute(PDO::MYSQL_ATTR_INIT_COMMAND, 'SET NAMES utf8'); // pour mysql/mariadb | ||
28 | $this->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // $this pour la méthode du parent PDO | ||
29 | $this->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); // pour PDO:fetch() et PDO::fetchAll() | ||
30 | // avec PDO::FETCH_ASSOC on obtient un tableau associatif, marche très bien puisqu'on utilise déjà des ID avec incrémentation automatique | ||
31 | // avec PDO::FETCH_BOTH (par défaut) on récupère les données en double (identifiants partant de 0 + tableau associatif) | ||
32 | } | ||
33 | catch(PDOException $e) | ||
34 | { | ||
35 | die("Impossible de se connecter à la base de données.\n" . $e->getMessage()); | ||
36 | } | ||
37 | } | ||
38 | |||
39 | // créer son objet avec: $Bdd = parent::getInstance(); | ||
40 | public static function getInstance(): self | ||
41 | { | ||
42 | if(self::$Instance === null) | ||
43 | { | ||
44 | self::$Instance = new self(); | ||
45 | } | ||
46 | return self::$Instance; | ||
47 | } | ||
48 | } | ||