Intereting Posts
Перенести все новые электронные письма в базу данных почему этот mysql-запрос не работает? SQL-запрос для расчета общего количества заказов в день? Найти самый старый файл в папке с помощью PHP Что лучше в цикле foreach … с использованием символа & или переназначения на основе ключа? Как разобрать объект PHP, когда имя атрибута *? Обязательные пользовательские поля проверки WooCommerce не подтверждают введенное значение PHP, что лучше всего подходит для использования XML? Нужно создавать и анализировать ответы XML Цель обучения C (Cocoa) для программирования iPhone, поступающего из веб-разработки? SimpleXML: работа с XML, содержащим пространства имен Как обновить базу данных mysql без перезагрузки страницы Как аннулировать кеш контейнера в Symfony2? Как вы управляете процессом сборки ? Cakephp сохраняет дополнительный атрибут в отношении HABTM WooCommerce: назначение конечной точки настраиваемому шаблону на моих учетных страницах

Ошибка PDOException?

Я получаю следующую ошибку в 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 

Сама ошибка не является проблемой , я намеренно прекратил работу службы 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. } 

Что мне здесь не хватает?

Единственное, о чем я могу думать, это то, что вы находитесь внутри класса с \PDOException и должны использовать \PDOException вместо PDOException .

Включите error_reporting и проверьте ошибки.

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

Может быть, есть фатальная ошибка, перед этой линией, или, возможно, PDO недоступен.