6

PHPで次のエラーが発生します。

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

エラー自体は問題ではありません。何が起こったのかを確認するために、意図的に Windows のMySQLサービスを終了しました (私は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.
}

ここで何が欠けていますか?

4

2 に答える 2

23

私が考えることができる唯一のことは、名前空間クラス内にいて、の\PDOException代わりに使用する必要があるかどうかですPDOException

于 2012-06-05T02:31:36.203 に答える
2

error_reportingをオンにして、エラーを確認します。

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

その行の前に致命的なエラーがあるか、PDOが利用できない可能性があります。

于 2012-06-05T02:36:22.987 に答える