目前我在数据库配置文件中使用Cakephp中的动态数据库切换。我正在基于子域进行切换,即:TEST.mysite.com和PROD.mysite.com。
如果有数据库连接,如何以及在哪里测试和重定向?
谢谢,
k Seudo
答案 0 :(得分:2)
快速而肮脏的方法是在构造函数中添加一个条件。我说脏,因为它创建了一个条件配置,并且引入一个错误可能会使您的生产应用程序连接到开发数据库。
class DATABASE_CONFIG {
public $default = array(
'driver' => 'mysql',
'persistent' => false,
'host' => '',
'login' => '',
'password' => '',
'database' => '',
'prefix' => '',
'encoding' => 'utf8'
);
public $testDB = array(
'driver' => 'mysql',
'persistent' => false,
'host' => '',
'login' => '',
'password' => '',
'database' => '',
'prefix' => '',
'encoding' => 'utf8'
);
public function __construct()
{
if (false !== stripos($_SERVER['HTTP_HOST'], 'test'))
{ // Use the test DB since 'test' is present in the server host
$this->default = $testDB;
}
}
}
要测试连接,您可以将以下内容放在app_model.php
的构造函数中public function __construct()
{
parent::__construct();
$db =& ConnectionManager::getDataSource('default');
if (empty($db->connection))
{
echo 'oh noes we werent able to connect';
exit;
}
}