我刚刚阅读了 Rob Allen 的 akrabat ZF2 教程 (http://akrabat.com/wp-content/uploads/Getting-Started-with-Zend-Framework-2.pdf),了解如何将依赖项注入(inject)您的内容,例如,将表适配器注入(inject)表类。
这似乎是我应该做的:
array(
'Application\Model\DbTable\UserTable',
) => array(
'parameters' => array(
'config' => 'Zend\Db\Adapter\PdoMysql',
)
),
array(
'Application\Model\DbTable\UserProfileTable',
) => array(
'parameters' => array(
'config' => 'Zend\Db\Adapter\PdoMysql',
)
),
好吧,这很酷,但我有大约 84 个表,所以我必须添加每个表,并说我希望 PdoMySQL 全部注入(inject)到它们中。是否有任何正确的方法来执行此操作,例如指定我的整个 DbTable 文件夹?即使这样也行不通:
array(
'Application\Model\DbTable\UserTable',
'Application\Model\DbTable\UserProfileTable'
) => array(
'parameters' => array(
'config' => 'Zend\Db\Adapter\PdoMysql',
)
),
还有其他人这样做并找到了更好的解决方案吗?
谢谢,多姆
最佳答案
你的问题很好,我同意,在这种情况下依赖注入(inject)没有意义。我还没有浏览过 ZF2 API,他们是否完全放弃了在连接级别而不是表级别绑定(bind)适配器的能力?
在我的数据库类中,我使用 yaml 文件来存储连接设置;用户名、密码、适配器等。我采用的格式可以直接传递给 Zend_Config,然后可以传递给 Zend_Db 类。
// Entry in connection.yml
database:
adapter: Pdo_Mysql
params:
host: myhost
dbname: mydatabase
username: myusername
password: mypassword
// Parse yaml file to get above snippet in an array ($dbConnectionparams)
$config = new Zend_Config($dbConnectionParams);
$dbo = Zend_Db::factory($config->database);
现在,如果我需要更改数据库连接的适配器,我只需在一个位置更改它,即 connection.yml 文件。
此外,我相信您可以以各种其他格式(xml 等)存储这种类型的连接数据。
关于php - Zend Framework 2 - DI 并且必须将表适配器注入(inject)表中......乏味吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8141755/