程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php設計模式 適配器模式,php設計模式

php設計模式 適配器模式,php設計模式

編輯:關於PHP編程

php設計模式 適配器模式,php設計模式


適配器模式,可以將截然不同的函數接口封裝成統一的API;

應用舉例,PHP的數據庫操作有Mysql、Mysqli、pdo三種,可以用適配器模式統一成一致,類似的場景還有cache適配器,將memcache、redis,file,apc等不同的緩存函數統一成一致。

IDatabase.php

<?php
namespace Baobab;

interface IDatabase{
    function connect($host, $user, $passwd, $dbname);
    function query($sql);
    function fetch_result($result);
    function close();
}

Mysqli.php

<?php
namespace Baobab\Database;

use Baobab\IDatabase;
class Mysqli implements IDatabase{
    protected $conn;
    function connect($host, $user, $passwd, $dbname){
        $conn = mysqli_connect($host, $user, $passwd, $dbname);
        mysqli_set_charset($conn, 'utf8');
        $this->conn = $conn;
    }
    
    function query($sql) {
        return mysqli_query($this->conn, $sql);
    }
    
    function fetch_result($result){
        return mysqli_fetch_all($result);
    }
    
    function close() {
        mysqli_close($this->conn);
    }
}

Pdo.php

<?php
namespace Baobab\Database;

use Baobab\IDatabase;
class Pdo implements IDatabase{
    protected $conn;
    function connect($host, $user, $passwd, $dbname){
       $conn =  new \PDO("mysql:dbname=$dbname;host=$host", $user, $passwd);
       $this->conn = $conn;
    }
    
    function query($sql){
        return $this->conn->query($sql);
    }
    
    function fetch_result($result){
        
    }
    
    function close() {
        unset($this->conn);
    }
}

index.php

$db = new Baobab\Database\Mysqli();
$db->connect('127.0.0.1', 'root', '', 'test');
$res = $db->query('select * from ha_cl');
print_r($db->fetch_result($res));
$db->close();

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved