前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[PHP] 使用适配器模式处理数据库对象

[PHP] 使用适配器模式处理数据库对象

作者头像
唯一Chat
发布2021-04-01 09:56:45
3800
发布2021-04-01 09:56:45
举报
文章被收录于专栏:陶士涵的菜地

适配器模式的定义:

将一个类的接口转换成客户希望的另外一个接口。Adapter模式使得原来由于接口不兼容而不能一起工作的那此类可以一起工作

包括两种模式:

类适配器模式与对象适配器

类适配器:Adapter类与被适配类是继承关系

对象适配器:Adapter对象与被适配类对象是委托关系 , 委托关系就是通过构造函数或者方法传入被适配对象

PDOAdapter 继承 PDO类 , 扩展里面的方法 , 这就是类适配器模式

ArticleModel传入PDOAdapter 对象 , 扩展PDOAdapter 对象的方法 , 这就是对象适配器

代码语言:javascript
复制
<?php
//类适配器
class PDOAdapter extends PDO{
    private $dsn = null;
    private $username = null;
    private $password = null;
    private $timeout = 30;
    private $charset = "utf8";
    private $options = array(
        PDO::ATTR_AUTOCOMMIT            => true,
        PDO::ATTR_ERRMODE               => PDO::ERRMODE_EXCEPTION,
        PDO::ATTR_DEFAULT_FETCH_MODE    => PDO::FETCH_ASSOC,
    );
    public function __construct($dsn, $username, $password, $timeout = null){
        $this->dsn = $dsn;
        $this->username = $username;
        $this->password = $password;
        $this->timeout = intval($timeout);
        parent::__construct($dsn, $username, $password, $this->options);
        $this->exec("set names ".$this->charset);
    }
    public function execute($sql, $params = array()){
        $stmt = $this->prepare($sql);
        $execStatus=$stmt->execute($params);
        return $execStatus;
    }
    public function getAll($sql, $params = array()){
        $stmt = $this->prepare($sql);
        $stmt->execute($params);
        return $stmt->fetchAll();
    }
}
//对象适配器,使用委派
class ArticleModel{
    private $pdo=null;
    public function __construct($pdo){
        $this->pdo=$pdo;
    }
    //委派调用PDOAdapter的getAll方法
    public function getArticleList(){
        $res=$this->pdo->getAll("select * from countries");
        return $res;
    }
}
class Controller{
  public function doAction(){
      try {
          $pdo=new PDOAdapter("mysql:host=127.0.0.1;port=3306;dbname=phpfly","phpfly","phpfly");
          $model=new ArticleModel($pdo);
          $res=$model->getArticleList();
          var_dump($res);

      } catch (Exception $e) {
          var_dump($e->getMessage());
      }

  }
}
$c=new Controller();
$c->doAction();
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-03-30 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档