|
工廠模式:專門定義一個類來負(fù)責(zé)創(chuàng)建其他類的實例,被創(chuàng)建的實例通常都具有其同的父類。工廠模式屬于類的創(chuàng)建模式,通常根據(jù)自變量的不同返回不同類的實例。
工廠模式的實質(zhì)是由一個工廠類根據(jù)傳入的參量,動態(tài)決定應(yīng)該創(chuàng)建出哪一個產(chǎn)品的實例。工廠模式式涉及到工廠角色、抽象產(chǎn)品角色和具體產(chǎn)品角色。
工廠(Creator)角色:是工廠模式的核心,它負(fù)責(zé)實現(xiàn)創(chuàng)建所有實例的內(nèi)部邏。工廠類可以被外界直接調(diào)用,創(chuàng)建所需產(chǎn)品對象。
抽象產(chǎn)品(Product)角色:是工廠模式所創(chuàng)建所有對象的父類,它負(fù)責(zé)描述所有實例所共有的公共接口。
具體產(chǎn)品(Concrete Product)角色:是工廠模式的創(chuàng)建目標(biāo),所有的對象都是充當(dāng)這個角色的某個具體類的實例。
ZF中的zend_db就是工廠模式的一個很好的例子。
接下來就開始進行分析。。。。。。
配置zf的時候,我們可以將數(shù)據(jù)庫的連接操作信息放在Bootstrap.php文件中
復(fù)制代碼 代碼如下:
<?php
class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
{
function __construct($app){
parent::__construct($app);
$url=constant('APPLICATION_PATH').DIRECTORY_SEPARATOR.'configs'.DIRECTORY_SEPARATOR.'config.ini';
$dbconfig=new Zend_Config_Ini($url,null,true);
$db=Zend_Db::factory($dbconfig->general->db->adapter,$dbconfig->general->db->params->toArray());
// var_dump($db);
$db->query('SET NAMES UTF8');
Zend_Db_Table::setDefaultAdapter($db);
}
}
?>
在入口文件處,通過一個Zend_Application對象來調(diào)用bootstrap(),類Bootstrap的構(gòu)造函數(shù)就會被調(diào)用。
在構(gòu)造函數(shù)中,通過Zend_Db::factory()我們就能得到一個操作數(shù)據(jù)庫的對象實例。
通過一個Zend_Config_Ini 實例讀取config.ini中相關(guān)信息作為參數(shù)傳遞給工廠函數(shù)Zend_Db::factory()
config.ini 的信息
[general]
db.adapter =PDO_MYSQL
db.params.host =localhost
db.params.username =root
db.params.password =
db.params.dbname = 數(shù)據(jù)庫名
Zend_Db::factory()
其中參數(shù)一:表示要操作的數(shù)據(jù)庫類型,比如PDO_MYSQL
參數(shù)二:表示連接數(shù)據(jù)庫的信息,包括服務(wù)器名,用戶名,密碼,要連接的數(shù)據(jù)庫
先拋出兩個提個問題:
①如果我們要操作的數(shù)據(jù)庫是MSSQL,該怎么操作
②這里我們使用的是Zend_Db::factory(),如果我們使用傳統(tǒng)的方式,該怎么操作
解答:
① 我們只需要在config.ini文件中將PDO_MYSQL修改成PDO_MSSQL即可
② 傳統(tǒng)方式創(chuàng)建一個操作數(shù)據(jù)庫的對象實例:
$db=new Zend_Db_Adapter_Pdo_Mysql($config)
其中:$config信息從config.ini中讀取
問題來了:我們使用傳統(tǒng)的方式來創(chuàng)建一個對象實例的話,我們必然有一個流程來判斷當(dāng)前要操作的數(shù)據(jù)庫類型吧?
比如:
復(fù)制代碼 代碼如下:
switch ($dbType){
case 'PDO_MYSQL':
....
case 'PDO_MSSQL':
....
case 'PDO_SQLITE':
....
}
我們還得根據(jù)不同的數(shù)據(jù)庫類型,寫不同的操作數(shù)據(jù)庫的語句,這樣豈不是很麻煩
但是,這一切的一切,zf通過工廠模式都已經(jīng)幫我們做好了,使用起來非常方便
Zf中如何是如何實現(xiàn)工廠模式的呢?
首先,得有一個抽象基類:Zend_Db_Adapter_Abstract,該類是工廠模式所創(chuàng)建的所有對象的父類,他負(fù)責(zé)提供所有實例要所共有的接口。
該類不僅提供了一些我們非常熟悉操作數(shù)據(jù)庫的實現(xiàn)方法,比如:select,update,insert,delete,query,fetchRow,fetchAssoc;另外,也提供了一些接口,用以在子類中進行實現(xiàn),比如:limit,getServerVersion,closeConnection,describeTable等等
復(fù)制代碼 代碼如下:
abstract class Zend_Db_Adapter_Abstract
{
//..
}
abstract class Zend_Db_Adapter_Pdo_Abstract extends Zend_Db_Adapter_Abstract
{
//..
}
class Zend_Db_Adapter_Pdo_Mysql extends Zend_Db_Adapter_Pdo_Abstract
{
//...實現(xiàn)針對Mysql數(shù)據(jù)庫的操作
}
class Zend_Db_Adapter_Pdo_Mssql extends Zend_Db_Adapter_Pdo_Abstract
{
//....實現(xiàn)針對Mssql數(shù)據(jù)庫的操作
}
class Zend_Db_Adapter_Pdo_Sqlite extends Zend_Db_Adapter_Pdo_Abstract
{
//....實現(xiàn)針對Sqlite數(shù)據(jù)庫的操作
}
以上關(guān)系可以用一張圖簡單的表示出來
接下來,我們跟蹤下Zend_Db::Factory()到底是實現(xiàn)根據(jù)不同的參數(shù)選擇不同的數(shù)據(jù)庫的。
php技術(shù):工廠模式在Zend Framework中應(yīng)用介紹,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。