处理Cakephp中的DB连接错误

时间:2012-03-20 10:58:09

标签: mysql database cakephp

目前我在数据库配置文件中使用Cakephp中的动态数据库切换。我正在基于子域进行切换,即:TEST.mysite.com和PROD.mysite.com。

如果有数据库连接,如何以及在哪里测试和重定向?

谢谢,

k Seudo

1 个答案:

答案 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;
    }
}