工廠模式在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)文章
從0構(gòu)建Oauth2Server服務?之Token?編解碼
這篇文章主要為大家介紹了從0構(gòu)建Oauth2Server服務之Token編解碼詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05PHP字符串與數(shù)組處理函數(shù)用法小結(jié)
這篇文章主要介紹了PHP字符串與數(shù)組處理函數(shù)用法,結(jié)合實例形式詳細分析了PHP字符串與數(shù)組常用處理函數(shù)功能、定義、使用方法與操作注意事項,需要的朋友可以參考下2020-01-01php實現(xiàn)用已經(jīng)過去多長時間的方式顯示時間
這篇文章主要介紹了php實現(xiàn)用已經(jīng)過去多長時間的方式顯示時間,可實現(xiàn)相對時間的顯示效果,非常具有實用價值,需要的朋友可以參考下2015-06-06PHP面向?qū)ο蟪绦蛟O(shè)計之對象的遍歷操作示例
這篇文章主要介紹了PHP面向?qū)ο蟪绦蛟O(shè)計之對象的遍歷操作,結(jié)合具體實例形式分析了php面向?qū)ο蟪绦蛟O(shè)計中對象屬性遍歷的相關(guān)操作技巧與注意事項,需要的朋友可以參考下2019-06-06php用數(shù)組返回無限分類的列表數(shù)據(jù)的代碼
php自定義函數(shù)之用數(shù)組返回無限分類的列表數(shù)據(jù),這樣的實現(xiàn)可以提高執(zhí)行的效率不要每次都從數(shù)據(jù)庫讀取數(shù)據(jù)。2010-08-08