2012-05-12 109 views
2

我在PDO中遇到困難。我擴展了PDO類,並且每次發生連接數據庫的錯誤時(錯誤的密碼等)它都不會捕獲異常。PDO連接異常捕獲

下面是當前的代碼:

public function __construct() { 
    $dsn = 'mysql:host=' . Config::host . 
      ';dbname=' . Config::db; 
    $user = Config::user; 
    $pass = Config::pass; 
    $opts = array(
     \PDO::ATTR_PERSISTENT => true, 
     \PDO::ATTR_ERRMODE => \PDO::ERRMODE_EXCEPTION 
    ); 

    try { 
     parent::__construct($dsn, $user, $pass, $opts); 
    } catch(PDOException $e) { 
     echo $e->getMessage(); 
    } 

} 

下面是顯示錯誤:

Fatal error: Uncaught exception 'PDOException' with message 
'SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost' 
(using password: YES)' in 
/home/rasmus/www/n1_cms/N1/Core/Database.php on line 21 

PDOException: SQLSTATE[HY000] [1045] Access denied for user 
'root'@'localhost' (using password: YES) in 
/home/rasmus/www/n1_cms/N1/Core/Database.php on line 21 

編輯:解

由於命名空間的使用沒有奏效。

更改:

catch(PDOException $e) 

要:

catch(\PDOException $e) 
+0

和拋出什麼樣的異常? –

+0

給主帖增加了錯誤。 – rasmusx

回答

0

移動的try/catch語句內parent::__construct($dsn, $user, $pass, $opts);

2

看來類的PDOException'不存在命名空間存在。嘗試更改catch塊:catch(\PDOException $e)

+0

是的,那是問題所在。謝謝。 – rasmusx