2007-04-19 20:41:19 +00:00
|
|
|
|
2007-04-13 21:49:11 +00:00
|
|
|
From the start Doctrine has been designed to work with multiple connections. Unless separately specified Doctrine always uses the current connection
|
|
|
|
for executing the queries. The following example uses openConnection() second argument as an optional
|
|
|
|
connection alias.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<code type="php">
|
|
|
|
// Doctrine_Manager controls all the connections
|
|
|
|
|
2007-05-07 15:42:26 +00:00
|
|
|
$manager = Doctrine_Manager::getInstance();
|
2007-04-13 21:49:11 +00:00
|
|
|
|
|
|
|
// open first connection
|
|
|
|
|
2007-05-07 15:44:20 +00:00
|
|
|
$conn = $manager->openConnection(new PDO('dsn','username','password'), 'connection 1');
|
2007-04-13 21:49:11 +00:00
|
|
|
</code>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
For convenience Doctrine_Manager provides static method connection() which opens new connection when arguments are given to it and returns the current
|
|
|
|
connection when no arguments have been speficied.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<code type="php">
|
|
|
|
// open first connection
|
|
|
|
|
2007-05-07 15:42:26 +00:00
|
|
|
$conn = Doctrine_Manager::connection(new PDO('dsn','username','password'), 'connection 1');
|
2007-04-13 21:49:11 +00:00
|
|
|
|
2007-05-07 15:42:26 +00:00
|
|
|
$conn2 = Doctrine_Manager::connection();
|
2007-04-13 21:49:11 +00:00
|
|
|
|
2007-05-07 15:40:22 +00:00
|
|
|
// $conn2 == $conn
|
2007-04-13 21:49:11 +00:00
|
|
|
</code>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
The current connection is the lastly opened connection.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<code type="php">
|
|
|
|
// open second connection
|
|
|
|
|
2007-05-07 15:42:26 +00:00
|
|
|
$conn2 = $manager->openConnection(new PDO('dsn2','username2','password2'), 'connection 2');
|
2007-04-13 21:49:11 +00:00
|
|
|
|
2007-05-07 15:42:26 +00:00
|
|
|
$manager->getCurrentConnection(); // $conn2
|
2007-05-07 15:41:08 +00:00
|
|
|
</code>
|
2007-04-13 21:49:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
You can change the current connection by calling setCurrentConnection().
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<code type="php">
|
2007-05-07 15:42:26 +00:00
|
|
|
$manager->setCurrentConnection('connection 1');
|
2007-04-13 21:49:11 +00:00
|
|
|
|
2007-05-07 15:42:26 +00:00
|
|
|
$manager->getCurrentConnection(); // $conn
|
2007-05-07 15:40:22 +00:00
|
|
|
|
2007-04-13 21:49:11 +00:00
|
|
|
</code>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
You can iterate over the opened connection by simple passing the manager object to foreach clause. This is possible since Doctrine_Manager implements
|
|
|
|
special IteratorAggregate interface.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<code type="php">
|
|
|
|
// iterating through connections
|
|
|
|
|
2007-05-07 15:42:26 +00:00
|
|
|
foreach($manager as $conn) {
|
2007-04-13 21:49:11 +00:00
|
|
|
|
|
|
|
}
|
2007-05-07 15:40:22 +00:00
|
|
|
</code>
|
2007-04-12 20:52:30 +00:00
|
|
|
|