程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> 工廠模式在Zend Framework中應用介紹

工廠模式在Zend Framework中應用介紹

編輯:PHP綜合
首先我們先引用些概念:
工廠模式:專門定義一個類來負責創建其他類的實例,被創建的實例通常都具有其同的父類。工廠模式屬於類的創建模式,通常根據自變量的不同返回不同類的實例。
工廠模式的實質是由一個工廠類根據傳入的參量,動態決定應該創建出哪一個產品的實例。工廠模式式涉及到工廠角色、抽象產品角色和具體產品角色。
工廠(Creator)角色:是工廠模式的核心,它負責實現創建所有實例的內部邏。工廠類可以被外界直接調用,創建所需產品對象。
抽象產品(Product)角色:是工廠模式所創建所有對象的父類,它負責描述所有實例所共有的公共接口。
具體產品(Concrete Product)角色:是工廠模式的創建目標,所有的對象都是充當這個角色的某個具體類的實例。
ZF中的zend_db就是工廠模式的一個很好的例子。
接下來就開始進行分析。。。。。。
配置zf的時候,我們可以將數據庫的連接操作信息放在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對象來調用bootstrap(),類Bootstrap的構造函數就會被調用。
在構造函數中,通過Zend_Db::factory()我們就能得到一個操作數據庫的對象實例。
通過一個Zend_Config_Ini 實例讀取config.ini中相關信息作為參數傳遞給工廠函數Zend_Db::factory()
config.ini 的信息
[general]
db.adapter =PDO_MYSQL
db.params.host =localhost
db.params.username =root
db.params.password =
db.params.dbname = 數據庫名
Zend_Db::factory()
其中參數一:表示要操作的數據庫類型,比如PDO_MYSQL
參數二:表示連接數據庫的信息,包括服務器名,用戶名,密碼,要連接的數據庫

先拋出兩個提個問題:
①如果我們要操作的數據庫是MSSQL,該怎麼操作
②這裡我們使用的是Zend_Db::factory(),如果我們使用傳統的方式,該怎麼操作

解答:
① 我們只需要在config.ini文件中將PDO_MYSQL修改成PDO_MSSQL即可
② 傳統方式創建一個操作數據庫的對象實例:
$db=new Zend_Db_Adapter_Pdo_Mysql($config)
其中:$config信息從config.ini中讀取
問題來了:我們使用傳統的方式來創建一個對象實例的話,我們必然有一個流程來判斷當前要操作的數據庫類型吧?
比如:
復制代碼 代碼如下:
switch ($dbType){
case 'PDO_MYSQL':
....
case 'PDO_MSSQL':
....
case 'PDO_SQLITE':
....
}

我們還得根據不同的數據庫類型,寫不同的操作數據庫的語句,這樣豈不是很麻煩
但是,這一切的一切,zf通過工廠模式都已經幫我們做好了,使用起來非常方便

Zf中如何是如何實現工廠模式的呢?
首先,得有一個抽象基類:Zend_Db_Adapter_Abstract,該類是工廠模式所創建的所有對象的父類,他負責提供所有實例要所共有的接口。
該類不僅提供了一些我們非常熟悉操作數據庫的實現方法,比如:select,update,insert,delete,query,fetchRow,fetchAssoc;另外,也提供了一些接口,用以在子類中進行實現,比如: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
{
//...實現針對Mysql數據庫的操作
}
class Zend_Db_Adapter_Pdo_Mssql extends Zend_Db_Adapter_Pdo_Abstract
{
//....實現針對Mssql數據庫的操作
}
class Zend_Db_Adapter_Pdo_Sqlite extends Zend_Db_Adapter_Pdo_Abstract
{
//....實現針對Sqlite數據庫的操作
}

以上關系可以用一張圖簡單的表示出來


接下來,我們跟蹤下Zend_Db::Factory()到底是實現根據不同的參數選擇不同的數據庫的。

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