使用数据库处理程序提供Zend应用程序的“正确”方法是什么?

时间:2009-11-14 20:42:10

标签: php database zend-framework

假设您正在密切关注ZendApplication的约定,您应该在哪里设置数据库处理程序以供应用程序开发人员访问?

我知道如何设置ZendDb适配器。我想知道的是,在Zend Framework的上下文中,开发人员应该如何实例化他们的数据库处理程序,这样他们就不必担心一个请求中的多个实例化,每次都提供凭据等等。

例如,当开发人员使用Code Igniter并需要运行任意查询时,控制器上就有一个数据库处理程序。

$this->db->query(....

这个约定的Zend等价物是什么?为了清楚起见,我可以想到使用Zend Framework提供的工具来实现这一目的的六种方法。我正在寻找的是Zend Framework在一般情况下如何要求你这样做。

1 个答案:

答案 0 :(得分:18)

我们的想法是你的Bootstrap读取一个配置文件并声明配置条目来描述你想要创建的数据库适配器:

[bootstrap]
resources.db.adapter = Pdo_Mysql
resources.db.params.dbname = "mydatabase"
resources.db.params.username = "webuser"
resources.db.params.password = "XXXX"
resources.db.isDefaultTableAdapter = true

如果按照正确的约定使用配置键,则会自动通知Bootstrap基类创建和初始化Zend_Application_Resource_Db对象,并将其存储在bootstrap resource registry中。

稍后在Controller中,您可以访问资源注册表。 注意: 我在测试后再编辑了这段代码。

class SomeController extends Zend_Controller_Action
{
    public function init()
    {
        $bootstrap = $this->getInvokeArg("bootstrap");
        if ($bootstrap->hasPluginResource("db")) {
            $dbResource = $bootstrap->getPluginResource("db");
            $db = $dbResource->getDbAdapter();
        }
    }
}

或者,您可以在Bootstrap类中编写自定义init方法,以将对象保存在默认的Zend_Registry中:

class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
{
  protected function _initDb()
  {
    if ($this->hasPluginResource("db")) {
      $dbResource = $this->getPluginResource("db");
      $db = $dbResource->getDbAdapter();
      Zend_Registry::set("db", $db);
    }
  }
}

现在,您可以一步而不是三步访问db对象:

class SomeController extends Zend_Controller_Action
{
    public function init()
    {
        $db = Zend_Registry::get("db");
    }
}

就个人而言,我会使用第二种技术,因为那时我只需要在我的引导程序中访问资源注册表一次。在第一个例子中,我必须将相同的代码块复制到我的所有控制器。

相关问题