如何在不修改Doctrine2内核中DriverManager.php的情况下添加自定义驱动程序?
我已经为pdo_dblib
创建了一个DBAL驱动程序,并将其放在一个Symfony2包中。这可以很好地工作,但是我必须将我的驱动程序添加到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
发布于 2012-01-05 02:23:45
您实际上可以,只要完全省略驱动程序配置选项即可。
您需要定义的只是driver_class选项。该驱动程序仅用于对默认驱动程序类进行内部查找,只要您只提供该类,它就不会失败。
顺便说一句:没有办法(在一个完整的默认设置中)在parameters.ini中定义它,您必须直接在config.yml中更改它
顺便说一下:由于另一个缺陷(驱动在特定区域回退到mysql ),您不能在配置中设置charset,因为它会注册一个MySql事件处理程序来设置charset than。
因此,基于我的基于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
发布于 2019-04-08 02:05:23
您可以使用选项driverClass:
$connectionParams = array(
'driverClass' => 'YOUR_CUSTOM_CLASS_DB',
);
$entityManager = \Doctrine\ORM\EntityManager::create($connectionParams, $config);
https://stackoverflow.com/questions/8492941
复制相似问题