2012-06-05 75 views
2

我收到以下錯誤PHPPDOException未被捕獲?

Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[HY000] [2003] Can't connect to MySQL server on 'localhost' (10061)' in C:\xampp\htdocs\project\Service\Database.class.php:26 Stack trace: #0 C:\xampp\htdocs\project\Service\Database.class.php(26): PDO->__construct('mysql:host=loca...', 'root', '', Array) #1 C:\xampp\htdocs\project\Service\Database.class.php(54): Service\Database::initialize() #2 C:\xampp\htdocs\project\index.php(15): Service\Database::getHandler() #3 {main} thrown in C:\xampp\htdocs\project\Service\Database.class.php on line 26 

錯誤本身是沒有問題的,我故意終止MySQL服務在Windows,看看發生了什麼(我使用XAMPP)。問題是,我無法捕捉到異常,PDO對象拋出,我不知道爲什麼。

try { 
    $host  = "localhost"; 
    $dbname  = "project"; 
    $userName = "root"; 
    $password = ""; 
    $charset = "utf8"; 
    $dsn  = "mysql:host=$host;dbname=$dbname;charset=$charset"; 

    $driverOptions = array(
     PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES $charset" 
    ); 

    // This is the line that supposedly throws the exception (LINE 26): 
    $dbh = new PDO($dsn, $userName, $password, $driverOptions); 

    $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); 

    self::setHandler($dbh); 
} catch (PDOException $e) { 
    die("CATCHED"); // This line is never reached 
} catch (Exception $e) { 
    die("CATCHED"); // nor this one. 
} 

我在這裏錯過了什麼?

回答

13

我能想到的唯一情況是,如果你在命名空間類中,並且應該使用\PDOException而不是PDOException

+3

哇,只是......你怎麼知道的?這解決了我的錯誤,謝謝你 – federicot

+0

那很快:)不客氣,很高興我能幫上忙。 –

+0

請介意接受系統中的答案,以便我可以使用我的Internet Pointz? –

1

打開error_reporting並檢查錯誤。

ini_set('display_errors', true); 
error_reporting(E_ALL); 

可能有一個致命的錯誤,在該行之前,或者也許PDO不可用。

相關問題