如何在不修改Doctrine2核心中的DriverManager.php的情况下添加我的自定义驱动程序?

我为pdo_dblib创建了DBAL驱动程序,并将其放置在Symfony2 bundle 软件中。这可以正常工作,但是我必须将我的驱动程序添加到DriverManager.php中的硬编码驱动程序列表中,否则会出现以下异常:

异​​常

[Doctrine\DBAL\DBALException]
The given 'driver' pdo_dblib is unknown, Doctrine currently supports only the following drivers: pdo_mysql, pdo_sqlite, pdo_pgsql, pdo_oci, oci8, ibm_db2, pdo_ibm, pdo_sqlsrv

除非我修改DriverManager.php否则

final class DriverManager
{
    private static $_driverMap = array(
        'pdo_dblib' => 'Doctrine\DBAL\Driver\PDODblib\Driver', // Added this line
    );
}

这是我的config.yml:

# Doctrine Configuration
doctrine:
    dbal:
        driver:         pdo_dblib
        driver_class:   PDODblibBundle\Doctrine\DBAL\Driver\PDODblib\Driver

最佳答案

实际上,您可以完全保留驱动程序配置选项。

您需要定义的只是driver_class选项。该驱动程序仅用于对默认驱动程序类进行内部查找,只要您仅提供该类,它就不会失败。

顺便说一句:没有方法(在完整的默认设置中)在parameters.ini中定义它,您必须直接在config.yml中对其进行更改

顺便说一句:由于另一个缺陷(驱动程序在特定区域退回到mysql),您可能未在配置中设置字符集,因为它将注册一个MySql事件处理程序来设置字符集。

因此,基于基于mssql_ *的实现的最终最终学说配置如下所示,并且可以正常工作:

# Doctrine Configuration
doctrine:
    dbal:
        #driver:   %database_driver%
        driver_class: Doctrine\DBAL\Driver\MsSql\Driver
        host:     %database_host%
        port:     %database_port%
        dbname:   %database_name%
        user:     %database_user%
        password: %database_password%
        #charset:  UTF8

    orm:
        auto_generate_proxy_classes: %kernel.debug%
        auto_mapping: true

07-25 22:14
查看更多