## 6-1 適配器模式
### 第一步:定義一個接口
*D:\wamp\www\demo\oop\framework\Think\IDatabase.php*
~~~
<?php
namespace Think;
// 定義一個數據庫的適配器接口類
interface IDatabase
{
function connect($host, $user, $passwd, $dbname);
function query($sql);
function close();
}
~~~
### 第二步:創建3個數據庫的操作類
接下來,我們分別實現上面的操作類,繼承同一個適配器接口,使用一致的操作數據庫方法。
**分別實現3種數據庫的操作**
*D:\wamp\www\demo\oop\framework\Think\Database\MySQL.php*
~~~
<?php
namespace Think\Database;
use Think\IDatabase;
class MySQL implements IDatabase
{
protected $conn;
function connect($host, $user, $passwd, $dbname)
{
$conn = mysql_connect($host, $user, $passwd);
mysql_select_db($dbname, $conn);
$this->conn = $conn;
}
function query($sql)
{
$ret = mysql_query($sql, $this->conn);
return $ret;
}
function close()
{
mysql_close($this->conn);
}
}
~~~
*D:\wamp\www\demo\oop\framework\Think\Database\MySQLi.php*
~~~
<?php
namespace Think\Database;
use Think\IDatabase;
class MySQLi implements IDatabase
{
protected $conn;
function connect($host, $user, $passwd, $dbname)
{
$conn = mysqli_connect($host, $user, $passwd, $dbname);
$this->conn = $conn;
}
function query($sql)
{
$res = mysqli_query($this->conn, $sql);
return $res;
}
function close()
{
mysqli_close($this->conn);
}
}
~~~
*D:\wamp\www\demo\oop\framework\Think\Database\PDO.php*
~~~
<?php
namespace Think\Database;
use Think\IDatabase;
class PDO implements IDatabase
{
function connect($host, $user, $passwd, $dbname)
{
$conn = new \PDO("mysql:host={$host}; dbname={$dbname}", $user, $passwd);
$this->conn = $conn;
}
function query($sql)
{
return $this->conn->query($sql);
}
function close()
{
unset($this->conn);
}
}
~~~
### 第三步:入口文件中,使用適配器模式實現數據庫的操作
*D:\wamp\www\demo\oop\framework\index.php*
~~~
<?php
// 入口文件
define('BASEDIR', __DIR__);
include BASEDIR . '/Think/Loder.php';
spl_autoload_register('\\Think\\Loder::autoload');
$db = new Think\Database\MySQLi();
$db->connect('localhost', 'root', 'root', 'demo');
$ret = $db->query('show databases');
$db->close();
var_dump($ret);
~~~
以上所述,我們使用適配器模式定義了一個接口,然后實現了3種數據庫的操作模式分別繼承這個接口,實現特定的3種方法。
最終,會大大的方便我們隨時切換數據庫的類型。
比如:
~~~
$db = new Think\Database\MySQL();
$db = new Think\Database\MySQLi();
$db = new Think\Database\PDO();
~~~
- 序言
- 第1章 課程簡介
- 1-1 大話PHP設計模式課程簡介
- 第2章 開發環境準備
- 2-1 關于PHPStorm使用
- 2-2 關于編程字體選擇
- 2-3 關于運行環境搭建
- 第3章 命名空間與Autoload
- 3-1 關于命名空間
- 3-2 類自動載入
- 3-3 開發一個PSR-0的基礎框架
- 第4章 PHP面向對象
- 4-1 SPL標準庫簡介
- 4-2 PHP鏈式操作的實現
- 4-3 PHP魔術方法的使用
- 第5章 三種基礎設計模式
- 5-1 工廠模式
- 5-2 單例模式
- 5-3 注冊樹模式
- 第6章 適配器模式
- 6-1 適配器模式
- 第7章 策略模式
- 7-1 策略模式的實現和使用
- 7-2 策略模式的控制反轉
- 第8章 數據對象映射模式
- 8-1 數據對象映射模式之簡單案例實現
- 8-2 數據對象映射模式之復雜案例實現
- 第9章 觀察者模式
- 第10章 原型模式
- 第11章 裝飾器模式
- 第12章 迭代器模式
- 第13章 代理模式
- 第14章 綜合實戰
- 14-1 面向對象設計基本原則
- 14-2 MVC結構
- 14-3 自動加載配置
- 14-4 從配置中生成數據庫連接
- 14-5 裝飾器模式在MVC中的使用
- 14-6 觀察者模式在MVC程序中的使用
- 14-7 代理模式在MVC程序中的使用
- 14-8 課程小結