use*_*700 3 php mysql doctrine symfony doctrine-orm
我试图在Symfony 2中使用doctrine进行多个数据库连接但不能这样做.
我已经在谷歌和堆栈溢出中进行了广泛搜索,但无论在哪里,它都是通过config.yml文件或动态数据库完成的,其中所有数据库都具有相同的模式/实体.
但对于我的情况,数据库是基于子域确定的,并且所有子域的数据库架构都不相同.
例如:
test1.example.com =>应该加载test1 db
test2.example.com =>将加载test2 db
test1和test2 DB都是不同的,它们是在DB级别创建的,并且在doctrine中没有实体条目.
任何人都可以帮助我在Symfony 2中如何做到这一点.
fer*_*tor 12
在我看来,使用Doctrines ODM并不是解决这个问题的正确方法.您仍然可以使用Doctrine连接到数据库并查询它们.但是如果你没有实体类,那么使用实体管理器似乎是不合适的.
以下是使用doctrine Connection类创建与数据库的连接的方法:
/** @var \Doctrine\Bundle\DoctrineBundle\ConnectionFactory $connectionFactory */
$connectionFactory = $this->getContainer()->get('doctrine.dbal.connection_factory');
$connection = $connectionFactory->createConnection(
array('pdo' => new \PDO("mysql:host=$hostname;dbname=$dbname", $username, $password))
);
Run Code Online (Sandbox Code Playgroud)
现在您可以将其$connection用作简单PDO对象:
$connection->executeQuery('SELECT * FROM your_table');
Run Code Online (Sandbox Code Playgroud)
您可以将此代码添加为服务,以使其随处可访问.
如果要连接到其他域的其他数据库,可以使用此代码来标识域:
$this->getRequest()->getHost();
Run Code Online (Sandbox Code Playgroud)
要在操作中访问域,请执行以下操作:
public function yourAction(Request $request, /* ... */)
{
// the Controller extends the Container. So need to get it here:
$connectionFactory = $this->get('doctrine.dbal.connection_factory');
// also access the domain like this:
$domain = $request->getHost();
}
Run Code Online (Sandbox Code Playgroud)