首页 > mysql教程 > 正文

如何写一个属于自己的数据库封装(1)

原创 2018-05-17 15:12:51 0 417

写在前头

  1. 依然在前进的菜鸟一只,错误什么的请轻喷指出

  2. 对于数据库连接由于较浅的工作经验所以无法完全覆盖,较复杂的query可能会有意想不到的bug

  3. 所以本系列只提供思路,成熟稳定的数据库封装有请自行搜索

  4. 编写该系列的初衷就是为了抛砖引玉, 在每一节的后端,我都会提出一些个人疑问(或无),希望能引出大神为我解答迷惑

  5. 使用的php版本为7.0+,该系列并不向下兼容,还在5.6版本的童鞋们快过来玩呀

  6. 数据库封装参考了laravel的源代码, 如有雷同, 不是巧合

最终效果

假设我们有一个表,名'Actor', 经过简单设置, 可以直接如下调用

$a = Actor::select('first_name', 'last_name')
        ->where('first_name', 'NICK')
        ->where('last_name', 'WAHLBERG')
        ->first()
var_dump($a);

返回格式

object(Actor)[11]
  public 'first_name' => string 'NICK' (length=4)
  public 'last_name' => string 'WAHLBERG' (length=8)

返回的数据依然可操作(update/delete)

$a->update(...);
$a->delete();

常见的数据库连接写法

对php有一定了解的人都知道,相比已被淘汰的mysql或取而代之的mysqli, pdo 可以避免SQL注入式攻击, 更安全, 而且面向对象, 所以以下以pdo作为例子

<?php
$driver='mysql'; //数据库类型

$host='localhost'; //数据库主机名

$db = 'sakila'; //数据库名称

$username='root'; //数据库连接用户名

$password=''; //数据库密码

$dsn="$driver:host=$host;dbname=$db";

try {    
    $pdo= new PDO($dsn, $username, $password); //初始化一个PDO对象   

    $sql = "select * from actor";

    $res = $pdo->query($sql); // 从actor中获取所有数据

    foreach($res as $row) echo $row['first_name']."<br>";

} catch (PDOException $e) {    
    die($e->getMessage());
}

以上例子非常简洁, 当一个项目逐渐成长,日渐复繁的时候,那么我们需要一个封装类来减少代码的重复性, 就像平时自行写的一些辅助函数, 不过封装类略微进阶而已。

基本思路

那么,应该怎么写呢?
首先, 平时我们要简略一些代码, 都会自行编写一些辅助函数,比如我个人有个不好的习惯,不喜欢用编辑器调试功能(画外音:我用的是sublime text 3),那么debug的时候一开始都是这么写的

$a = "is bug";
die(var_dump($a)); // 输出变量并且停止运行之后的代码
/***从xdebug得知bug出现在这一行,所以查看上一行的逻辑与数据 ***/

die(var_dump())的出场率略高, 因此我将它们写成了一个辅助函数

function dd($var) {
    die(var_dump($var));
}

同样道理,在数据库读取的时候,select的出场率极高, 所以简单的包裹一下

function select($pdo, $table, $require, $where = []) {
    $w = [];

    // 将搜索条件转化为数据库命令能接受的格式
    foreach ($where as $key => &$val) 
        $w[] = "$key = '$val'";

    // 有时候并不需要条件,仅仅将所有数据取出,因此$where默认为空
    if(!empty($w)) $w = "where ".implode(', ', $w);
    else $w = "";

    // 生成sql query
    $sql = "select $require from $table $w";

    // 将已生成的query带入pdo实例
    $res = $pdo->query($sql);

    // 返回结果
    return $res->fetchAll();
}

例子

select($pdo, 'actor', '*', ['first_name'=>'PENELOPE'])
/** 
  * 生成sql query => select * from actor where first_name = 'PENELOPE'
**/

总结一下, 数据库封装浅显的形容就是将参数带入辅助函数,让其自动生成SQL命令。

数据库封装的架构

主要分成四个文件

  • Connector.php - 负责与数据库的通信, 请求与返回数据库数据

  • Model.php - 入口文件,负责表的设置, 并接受请求, 返回回应

  • Grammar.php - 将Builder存储的请求转化为SQL语句

  • Builder.php - 核心文件, 存储Model的请求,调用Grammar以返回SQL语句, 与参数变量一并送往Connector以获取数据库数据,再返还给Model

架构可能解释得不太好,但没关系, 接下来会慢慢一个个的深入解释

大致如此, 如果可以的话点个赞,或在下方评论区讨论, 只有反馈才能推动一个懒癌晚期病患继续前行。

以上就是如何写一个属于自己的数据库封装(1)的详细内容,更多请关注php中文网其它相关文章!

  • 相关标签:数据库 自己的 属于 一个 如何
  • 本文原创发布php中文网 ,转载请注明出处,感谢您的尊重!
  • 相关文章


  • Mysql的底层封装
  • MySQL 主键与索引的联系与区别分析_Mysql
  • mysql5.5数据库data目录迁移方法详解_MySQL
  • 理解Mysql prepare预处理语句_MySQL
  • 如何写一个属于自己的数据库封装(1)
  • 网友评论

    文明上网理性发言,请遵守 新闻评论服务协议

    我要评论
    独孤九贱(4)_PHP视频教程

    独孤九贱(4)_PHP视频教程

    江湖传言:PHP是世界上最好的编程语言。真的是这样吗?这个梗究竟是从哪来的?学会本课程,你就会明白了。 PHP中文网出品的PHP入门系统教学视频,完全从初学者的角度出发,绝不玩虚的,一切以实用、有用...

    • PeterZhu
    • 2017-03-20 22:47:17
    • 点击数(110601)

    独孤九贱(5)_ThinkPHP5视频教程

    独孤九贱(5)_ThinkPHP5视频教程

    ThinkPHP是国内最流行的中文PHP开发框架,也是您Web项目的最佳选择。《php.cn独孤九贱(5)-ThinkPHP5视频教程》课程以ThinkPHP5最新版本为例,从最基本的框架常识开始,将...

    • PeterZhu
    • 2017-05-16 12:03:57
    • 点击数(108468)

    独孤九贱(1)_HTML5视频教程

    独孤九贱(1)_HTML5视频教程

    《php.cn原创html5视频教程》课程特色:php中文网原创幽默段子系列课程,以恶搞,段子为主题风格的php视频教程!轻松的教学风格,简短的教学模式,让同学们在不知不觉中,学会了HTML知识。 ...

    • PeterZhu
    • 2017-03-13 10:15:11
    • 点击数(83305)

    ThinkPHP5实战之[教学管理系统]

    ThinkPHP5实战之[教学管理系统]

    本套教程,以一个真实的学校教学管理系统为案例,手把手教会您如何在一张白纸上,从零开始,一步一步的用ThinkPHP5框架快速开发出一个商业项目。

    • PeterZhu
    • 2017-07-24 16:48:56
    • 点击数(82474)

    PHP入门视频教程之一周学会PHP

    PHP入门视频教程之一周学会PHP

    所有计算机语言的学习都要从基础开始,《PHP入门视频教程之一周学会PHP》不仅是PHP的基础部分更主要的是PHP语言的核心技术,是学习PHP必须掌握的内容,任何PHP项目的实现都离不开这部分的内容,通...

    • PHPzhong

      全栈工程师

    • 学习是最好的投资!
    • 546篇
      文章总数
    • 417
      文章总浏览数

    相关视频教程

  • javascript初级视频教程 javascript初级视频教程
  • jquery 基础视频教程 jquery 基础视频教程
  • javascript三级联动视频教程 javascript三级联动视频教程
  • 独孤九贱(3)_JavaScript视频教程 独孤九贱(3)_JavaScript视频教程
  • 独孤九贱(6)_jQuery视频教程 独孤九贱(6)_jQuery视频教程
  • 相关视频章节