Pdo.php 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. <?php
  2. /**
  3. * MINZ - Copyright 2011 Marien Fressinaud
  4. * Sous licence AGPL3 <http://www.gnu.org/licenses/>
  5. */
  6. abstract class Minz_Pdo extends PDO {
  7. public function __construct($dsn, $username = null, $passwd = null, $options = null) {
  8. parent::__construct($dsn, $username, $passwd, $options);
  9. $this->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
  10. }
  11. abstract public function dbType();
  12. private $prefix = '';
  13. public function prefix() { return $this->prefix; }
  14. public function setPrefix($prefix) { $this->prefix = $prefix; }
  15. private function autoPrefix($sql) {
  16. return str_replace('`_', '`' . $this->prefix, $sql);
  17. }
  18. protected function preSql($statement) {
  19. if (preg_match('/^(?:UPDATE|INSERT|DELETE)/i', $statement)) {
  20. invalidateHttpCache();
  21. }
  22. return $this->autoPrefix($statement);
  23. }
  24. // PHP8+: PDO::lastInsertId(?string $name = null): string|false
  25. #[\ReturnTypeWillChange]
  26. public function lastInsertId($name = null) {
  27. if ($name != null) {
  28. $name = $this->preSql($name);
  29. }
  30. return parent::lastInsertId($name);
  31. }
  32. // PHP8+: PDO::prepare(string $query, array $options = []): PDOStatement|false
  33. #[\ReturnTypeWillChange]
  34. public function prepare($statement, $driver_options = array()) {
  35. $statement = $this->preSql($statement);
  36. return parent::prepare($statement, $driver_options);
  37. }
  38. // PHP8+: PDO::exec(string $statement): int|false
  39. #[\ReturnTypeWillChange]
  40. public function exec($statement) {
  41. $statement = $this->preSql($statement);
  42. return parent::exec($statement);
  43. }
  44. // PHP8+: PDO::query(string $query, ?int $fetchMode = null, mixed ...$fetchModeArgs): PDOStatement|false
  45. #[\ReturnTypeWillChange]
  46. public function query($query, $fetch_mode = null, ...$fetch_mode_args) {
  47. $query = $this->preSql($query);
  48. return $fetch_mode ? parent::query($query, $fetch_mode, ...$fetch_mode_args) : parent::query($query);
  49. }
  50. }