Ce monsieur (Olivier
) avait le même problème ! (Il y a un an) Il a écrit
une petite adaptation pour le Controller
s! C'est assez petit et il s'avère que cela fonctionne en 1.3 et 2.x .
Quoi qu'il en soit, c'est ma solution finale, que j'ai mise dans le app/Model/AppModel.php
:
class AppModel extends Model
{
/**
* Connects to specified database
*
* @param String name of different database to connect with.
* @param String name of existing datasource
* @return boolean true on success, false on failure
* @access public
*/
public function setDatabase($database, $datasource = 'default')
{
$nds = $datasource . '_' . $database;
$db = &ConnectionManager::getDataSource($datasource);
$db->setConfig(array(
'name' => $nds,
'database' => $database,
'persistent' => false
));
if ( $ds = ConnectionManager::create($nds, $db->config) ) {
$this->useDbConfig = $nds;
$this->cacheQueries = false;
return true;
}
return false;
}
}
Et voici comment je l'ai utilisé dans mon app/Controller/CarsController.php
:
class CarsController extends AppController
{
public function index()
{
$this->Car->setDatabase('cake_sandbox_client3');
$cars = $this->Car->find('all');
$this->set('cars', $cars);
}
}
Je parie que je ne suis ni le premier ni le dernier à avoir ce problème. J'espère donc vraiment que ces informations trouveront des personnes et la communauté CakePHP.