工廠模式在Zend Framework中應用介紹
更新時間:2012年07月10日 02:40:16 作者:
在Zend Framework中,使用了多種設(shè)計模式。其中對數(shù)據(jù)庫的封裝,用到了工廠模式
首先我們先引用些概念:
工廠模式:專門定義一個類來負責創(chuàng)建其他類的實例,被創(chuàng)建的實例通常都具有其同的父類。工廠模式屬于類的創(chuàng)建模式,通常根據(jù)自變量的不同返回不同類的實例。
工廠模式的實質(zhì)是由一個工廠類根據(jù)傳入的參量,動態(tài)決定應該創(chuàng)建出哪一個產(chǎn)品的實例。工廠模式式涉及到工廠角色、抽象產(chǎn)品角色和具體產(chǎn)品角色。
工廠(Creator)角色:是工廠模式的核心,它負責實現(xiàn)創(chuàng)建所有實例的內(nèi)部邏。工廠類可以被外界直接調(diào)用,創(chuàng)建所需產(chǎn)品對象。
抽象產(chǎn)品(Product)角色:是工廠模式所創(chuàng)建所有對象的父類,它負責描述所有實例所共有的公共接口。
具體產(chǎn)品(Concrete Product)角色:是工廠模式的創(chuàng)建目標,所有的對象都是充當這個角色的某個具體類的實例。
ZF中的zend_db就是工廠模式的一個很好的例子。
接下來就開始進行分析。。。。。。
配置zf的時候,我們可以將數(shù)據(jù)庫的連接操作信息放在Bootstrap.php文件中
<?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ù)庫的信息,包括服務器名,用戶名,密碼,要連接的數(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)建一個對象實例的話,我們必然有一個流程來判斷當前要操作的數(shù)據(jù)庫類型吧?
比如:
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)建的所有對象的父類,他負責提供所有實例要所共有的接口。
該類不僅提供了一些我們非常熟悉操作數(shù)據(jù)庫的實現(xiàn)方法,比如:select,update,insert,delete,query,fetchRow,fetchAssoc;另外,也提供了一些接口,用以在子類中進行實現(xiàn),比如:limit,getServerVersion,closeConnection,describeTable等等
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)系可以用一張圖簡單的表示出來
工廠模式:專門定義一個類來負責創(chuàng)建其他類的實例,被創(chuàng)建的實例通常都具有其同的父類。工廠模式屬于類的創(chuàng)建模式,通常根據(jù)自變量的不同返回不同類的實例。
工廠模式的實質(zhì)是由一個工廠類根據(jù)傳入的參量,動態(tài)決定應該創(chuàng)建出哪一個產(chǎn)品的實例。工廠模式式涉及到工廠角色、抽象產(chǎn)品角色和具體產(chǎn)品角色。
工廠(Creator)角色:是工廠模式的核心,它負責實現(xiàn)創(chuàng)建所有實例的內(nèi)部邏。工廠類可以被外界直接調(diào)用,創(chuàng)建所需產(chǎn)品對象。
抽象產(chǎn)品(Product)角色:是工廠模式所創(chuàng)建所有對象的父類,它負責描述所有實例所共有的公共接口。
具體產(chǎn)品(Concrete Product)角色:是工廠模式的創(chuàng)建目標,所有的對象都是充當這個角色的某個具體類的實例。
ZF中的zend_db就是工廠模式的一個很好的例子。
接下來就開始進行分析。。。。。。
配置zf的時候,我們可以將數(shù)據(jù)庫的連接操作信息放在Bootstrap.php文件中
復制代碼 代碼如下:
<?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ù)庫的信息,包括服務器名,用戶名,密碼,要連接的數(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)建一個對象實例的話,我們必然有一個流程來判斷當前要操作的數(shù)據(jù)庫類型吧?
比如:
復制代碼 代碼如下:
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)建的所有對象的父類,他負責提供所有實例要所共有的接口。
該類不僅提供了一些我們非常熟悉操作數(shù)據(jù)庫的實現(xiàn)方法,比如:select,update,insert,delete,query,fetchRow,fetchAssoc;另外,也提供了一些接口,用以在子類中進行實現(xiàn),比如:limit,getServerVersion,closeConnection,describeTable等等
復制代碼 代碼如下:
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ù)庫的。

您可能感興趣的文章:
- Zend Framework開發(fā)入門經(jīng)典教程
- Zend Framework入門之環(huán)境配置及第一個Hello World示例(附demo源碼下載)
- Zend Framework入門知識點小結(jié)
- Zend Framework 2.0事件管理器(The EventManager)入門教程
- Zend Framework入門教程之Zend_View組件用法示例
- Zend Framework入門教程之Zend_Registry組件用法詳解
- Zend Framework入門教程之Zend_Config組件用法詳解
- Zend Framework入門教程之Zend_Session會話操作詳解
- Zend Framework入門教程之Zend_Mail用法示例
- Zend Framework入門教程之Zend_Db數(shù)據(jù)庫操作詳解
- Zend Framework入門應用實例詳解
相關(guān)文章
如何獲知PHP程序占用多少內(nèi)存(memory_get_usage)
想要知道編寫的 PHP 腳本需要占用多少內(nèi)存么?很簡單,直接使用 PHP 查看當前分配給 PHP 腳本的內(nèi)存的函數(shù) memory_get_usage() 就可以了2012-09-09
異步加載技術(shù)實現(xiàn)當滾動條到最底部的瀑布流效果
當滾動條到最底部的時候觸發(fā)一個事件,這個事件寫入$.get()事件,實現(xiàn)瀑布流效果,下面試具體的實現(xiàn)2014-09-09
ie與session丟失(新窗口cookie丟失)實測及解決方案
正如標題所言測試結(jié)果為:如果cookie設(shè)置是延后定時失效,而非進程級的,那在open后也能看到,所以,針對此情況,防止用戶在使用ie內(nèi)核出現(xiàn)登錄狀態(tài)丟失,可以配合cookie來使用2013-07-07
php求斐波那契數(shù)的兩種實現(xiàn)方式【遞歸與遞推】
這篇文章主要介紹了php求斐波那契數(shù)的兩種實現(xiàn)方式,結(jié)合實例形式分析了php使用遞歸與遞推算法實現(xiàn)求斐波那契數(shù)的相關(guān)操作技巧與注意事項,需要的朋友可以參考下2019-09-09

