工厂模式在Zend Framework中应用介绍
程序员文章站
2023-11-12 20:55:10
首先我们先引用些概念: 工厂模式:专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有其同的父类。工厂模式属于类的创建模式,通常根据自变量的不同返回不同类的实例。...
首先我们先引用些概念:
工厂模式:专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有其同的父类。工厂模式属于类的创建模式,通常根据自变量的不同返回不同类的实例。
工厂模式的实质是由一个工厂类根据传入的参量,动态决定应该创建出哪一个产品的实例。工厂模式式涉及到工厂角色、抽象产品角色和具体产品角色。
工厂(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数据库的操作
}
以上关系可以用一张图简单的表示出来
工厂模式:专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有其同的父类。工厂模式属于类的创建模式,通常根据自变量的不同返回不同类的实例。
工厂模式的实质是由一个工厂类根据传入的参量,动态决定应该创建出哪一个产品的实例。工厂模式式涉及到工厂角色、抽象产品角色和具体产品角色。
工厂(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()到底是实现根据不同的参数选择不同的数据库的。