php如何封装数据库增删改的类

后端开发   发布日期:2023年10月04日   浏览次数:362

本文小编为大家详细介绍“php如何封装数据库增删改的类”,内容详细,步骤清晰,细节处理妥当,希望这篇“php如何封装数据库增删改的类”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

1.为什么需要封装数据库类?

通常情况下,在进行数据库操作时,我们会在应用程序的主要逻辑中进行操作,比如在控制器中操作数据库。但实际上,这种方式存在几个明显的问题:

  • 代码冗余:在我们的应用程序中,很可能多个控制器需要对数据库进行操作。如果每个控制器都单独编写数据库操作的代码,那么就会出现大量的冗余代码。

  • 代码可读性差:这种情况下,代码的可读性也就差了。很可能我们同一段代码就出现在多个控制器中,这样一来,就会给其他开发人员带来困扰。

  • 安全问题:将数据库操作代码直接写在应用程序中,存在一定的安全风险。比如sql注入等问题。

综上所述,我们有必要将我们的数据库操作代码封装起来,让它们成为一个独立的模块。这个模块需要具有以下几个特点:

  • 具有良好的可读性

  • 能够方便的进行代码复用

  • 具有良好的扩展性

  • 能够有效的解决安全问题

2.封装数据库增删改类的基本思路

针对上面提到的问题,我们可以把类写成php库的形式,以便实现类的复用。封装数据库增删改类的基本思路如下:

  • 将所有的数据库操作都封装在一个类中,比如叫做db类。

  • 编写通用的方法来实现数据库增删改查操作。

  • 在方法中实现参数化查询,从而有效的避免sql注入等安全问题。

  • 将所有的错误信息都捕获,并且封装成一个统一的异常抛出给上层代码。

下面是一个简单的db类的实现:

  1. class db {
  2. private $db_host;
  3. private $db_user;
  4. private $db_pass;
  5. private $db_name;
  6. private $conn;
  7. function __construct($db_host, $db_user, $db_pass, $db_name) {
  8. $this->db_host = $db_host;
  9. $this->db_user = $db_user;
  10. $this->db_pass = $db_pass;
  11. $this->db_name = $db_name;
  12. }
  13. // 数据库连接方法
  14. function connect() {
  15. $this->conn = mysqli_connect($this->db_host, $this->db_user, $this->db_pass, $this->db_name);
  16. if (!$this->conn) {
  17. throw new Exception('数据库连接失败');
  18. }
  19. mysqli_query($this->conn, "SET NAMES 'utf8'");
  20. }
  21. // 数据库关闭方法
  22. function close() {
  23. mysqli_close($this->conn);
  24. }
  25. // 查询方法,参数化查询
  26. function query($sql, $params) {
  27. $stmt = mysqli_prepare($this->conn, $sql);
  28. if (!$stmt) {
  29. throw new Exception('query error: '.mysqli_error($this->conn));
  30. }
  31. if (count($params) > 0) {
  32. call_user_func_array('mysqli_stmt_bind_param', array_merge(array($stmt, str_repeat('s', count($params))), $params));
  33. }
  34. $result = mysqli_stmt_execute($stmt);
  35. if (!$result) {
  36. throw new Exception('query error: '.mysqli_stmt_error($stmt));
  37. }
  38. $rows = array();
  39. $meta = mysqli_stmt_result_metadata($stmt);
  40. if ($meta) {
  41. while ($field = mysqli_fetch_field($meta)) {
  42. $params[] = &$row[$field->name];
  43. }
  44. call_user_func_array(array($stmt, 'bind_result'), $params);
  45. while (mysqli_stmt_fetch($stmt)) {
  46. $rows[] = $row;
  47. }
  48. }
  49. mysqli_stmt_close($stmt);
  50. return $rows;
  51. }
  52. // 增加方法,参数化查询
  53. function insert($table, $data) {
  54. $sql = 'INSERT INTO '.$table.' ('.implode(',', array_keys($data)).') VALUES ('.implode(',', array_fill(0, count($data), '?')).')';
  55. $result = $this->query($sql, array_values($data));
  56. return mysqli_affected_rows($this->conn);
  57. }
  58. // 更新方法
  59. function update() {
  60. // 实现更新方法
  61. }
  62. // 删除方法
  63. function delete() {
  64. // 实现删除方法
  65. }
  66. }

3.使用封装好的类

当我们需要对数据库进行增删改查时,只需要引入db类,然后实例化即可。比如:

  1. require_once 'db.php';
  2. $db = new db('localhost', 'root', 'root', 'test');
  3. $db->connect();
  4. $sql = 'INSERT INTO `user`(`name`, `age`) VALUES (?, ?)';
  5. $data = array('Tom', '18');
  6. $db->query($sql, $data);
  7. $db->close();

以上就是php如何封装数据库增删改的类的详细内容,更多关于php如何封装数据库增删改的类的资料请关注九品源码其它相关文章!