4

上下文优先:基于Zend Framework 2的Apigility驱动应用程序。在第一个版本 ( ) 中,我使用的是模型层。现在我正在使用Doctrine 2作为 ORM 来实现。V1ZfcBase DbMapperV2

Apigility 提供了版本之间的轻松切换,每个版本都可以使用自己的数据库适配器:

/config/autoload/global.php//config/autoload/local.php

<?php
return array(
    ...
    'db' => array(
        'adapters' => array(
            'DB\\myproject_v1' => array(
                // settings (driver, hostname, database, driver_options)
                // credentials (username, password)
                ...
            ),
            'DB\\myproject_v2' => array(
                // settings (driver, hostname, database, driver_options)
                // credentials (username, password)
                ...
            ),
        ),
    ),
    ...
);

因此,要使用另一个版本作为默认版本,后面还有另一个数据库,只需更改 URL:

myproject.tld/my-endpoint    <-- version set to default
myproject.tld/v1/my-endpoint <-- version 1
myproject.tld/v2/my-endpoint <-- version 2

我想将 Doctrine 2 添加到我的应用程序中,所以我扩展了我的local.php如下所示

<?php
return array(
    ...
    'doctrine' => array(
        'connection' => array(
            'orm_default' => array(
                'driverClass' => 'Doctrine\DBAL\Driver\PDOMySql\Driver',
                'params' => array(
                    // settings (host, port, dbname)
                    // credentials (user, password)
                    ...
                ),
            ),
        ),
    ),
    ...
);

它正在工作,但现在我没有在版本之间切换/使用不同版本和不同数据库的灵活性。我的适配器设置被教义连接配置覆盖或被忽略。

如何将 Doctrine 与 Apigility 的版本控制灵活性结合起来?如何使用 Doctrine 在 Apigility 应用程序中配置数据库连接并保持能够在版本之间切换/同时使用多个版本?

4

1 回答 1

1

配置的以下部分:

[
    'db'=>[
        'adapters' => [
            'DB\\myproject_v1' => [],
            'DB\\myproject_v2' => [],
        ]
    ]
]

配置一个注册服务名称DB\\myproject_v1DB\\myproject_v2数据库适配器实例的抽象工厂。

它是下面配置的一部分,实际上将适配器分配给您的数据库连接资源:

'db-connected' => array(
    'YourDBConnectedResource' => array(
        'adapter_name'     => 'DB\\myproject_v1',
    ),
),

Doctrine 提供了它自己的抽象工厂和配置,所以为了让 Apigility 使用 Doctrine 作为你的数据库适配器,你只需要稍微调整一下配置。首先,让我们在您的学说配置中添加第二个连接以帮助说明更改。

return [
    'doctrine' => [
        'connection' => [
            'orm_default' => [ // you don't have to use orm_default, you can arbitrarily name this version1
                'driverClass' => 'Doctrine\DBAL\Driver\PDOMySql\Driver',
                'params' => [
                    // settings (host, port, dbname)
                    // credentials (user, password)

                ],
            ],
            'version2' => [
                'driverClass' => 'Doctrine\DBAL\Driver\PDOMySql\Driver',
                'params' => [
                    // settings (host, port, dbname)
                    // credentials (user, password)
                ],
            ],            
        ],
    ],
];

现在,您的数据库适配器名称是doctrine.connection.orm_defaultdoctrine.connection.version2。所以你在你的 db-connected 配置块中替换那些。

'db-connected' => [
    'My\\Endpoint\\V1\\Rest\\MyResource' => [
        'adapter_name'     => 'doctrine.connection.orm_default',
    ],
    'My\\Endpoint\\V2\\Rest\\MyResource' => [
        'adapter_name'     => 'doctrine.connection.version2',
    ],
],
于 2015-04-28T21:11:24.567 回答