如何将现有PDO对象注入到doctrine实体管理器中

时间:2017-04-19 09:30:29

标签: php pdo doctrine-orm doctrine

我想使用doctrine实体管理器创建一个PHP包。

这个软件包将在我公司的不同项目中使用,有些项目不使用doctrine,而是使用PDO连接。

我希望能够使用现有的独立PDO对象在我的包中实例化一个doctrine实体管理器,因为我不想(而且我不能)创建另一个数据库连接。我必须使用现有的。

这是一种方法吗?类似的东西:

$ em = EntityManager :: createWithPDOInstance($ pdoObject);

谢谢

2 个答案:

答案 0 :(得分:2)

好吧,我自己找到了解决方案。

我发布了代码,将来可能对某人有帮助。

<?php

namespace MyProject\Factory;

use Doctrine\Common\Annotations\AnnotationReader;
use Doctrine\Common\Annotations\AnnotationRegistry;
use Doctrine\DBAL\DriverManager;
use Doctrine\ORM\Configuration;
use Doctrine\ORM\EntityManager;
use Doctrine\ORM\Mapping\Driver\AnnotationDriver;

class EntityManagerFactory
{
    /**
     * @param \PDO $pdo
     * @return EntityManager
     */
    public function create(\PDO $pdo)
    {
        $config = new Configuration();
        $config->setProxyDir(__DIR__ . '/EntityProxy');
        $config->setProxyNamespace('EntityProxy');
        $config->setAutoGenerateProxyClasses(true);

        AnnotationRegistry::registerFile(__DIR__ . '/../../vendor/doctrine/orm/lib/Doctrine/ORM/Mapping/Driver/DoctrineAnnotations.php');

        $config->setMetadataDriverImpl(new AnnotationDriver(
            new AnnotationReader(),
            array(__DIR__ . '/')
        ));

        return EntityManager::create(
            DriverManager::getConnection(
                [
                    'driver' => 'pdo_' . $pdo->getAttribute(\PDO::ATTR_DRIVER_NAME),
                    'pdo' => $pdo,
                ],
                $config),
            $config
        );
    }
}

答案 1 :(得分:0)

我尝试了您的方法,并且大部分时间都在工作。我遇到的问题是我的实体还具有JmsSerializer批注。当我试图找到一个实体时,它抛出了一个异常,即无法识别JmsSerializer注释。

要解决此问题,我将AnnotationRegistry::registerFile更改为 AnnotationRegistry::registerLoader('class_exists');并解决了我的错误