Как обрабатывать исключения PDO [дублировать]

17

Я пытаюсь работать с PDO class на php, но у меня есть некоторые проблемы, чтобы найти правильный способ обработки ошибок, я написал этот код:

<?php
// $connection alreay created on a class which works with similar UPDATE statements
// I've simply added here trim() and PDO::PARAM... data type


$id = 33;
$name = "Mario Bros.";
$url = "http://nintendo.com";
$country = "jp";


try {

$sql = "UPDATE table_users SET name = :name, url = :url, country = :country WHERE user_id = :user_id";

$statement = $connection->prepare ($sql);

$statement->bindParam (':user_id', trim($id), PDO::PARAM_INT);
$statement->bindParam (':name', trim($name), PDO::PARAM_STR);
$statement->bindParam (':url', trim($url), PDO::PARAM_STR);
$statement->bindParam (':country', trim($country), PDO::PARAM_STR, 2);

$status = $statement->execute ();

} catch (PDOException $e) {
    print $e->getMessage ();
}

print $status; // it returns a null value, and no errors are reported

?>

эта часть кода не сообщает об ошибках, но она просто не работает, var $status внизу, возвращает нулевое значение.

может кто-нибудь помочь мне найти, где я ошибаюсь?

    
задан vitto 20.01.2010 в 20:57
источник

2 ответа

41

PDO не будет генерировать исключения, если вы не сообщите об этом. Вы запустили:

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

на объекте PDO?

    
ответ дан Matchu 20.01.2010 в 21:02
источник
  • просто и быстро! благодаря –  vitto 20.01.2010 в 21:03
  • @Matchu: Это поведение по умолчанию? С каких пор?! –  Alix Axel 20.01.2010 в 21:09
  • Поскольку я последний раз построил класс базы данных месяц назад или около того. По крайней мере, в моей среде тихий режим был по умолчанию. –  Matchu 20.01.2010 в 21:13
  • Найдено - us3.php.net/manual/en/pdo.error-handling.php - «PDO :: ERRMODE_SILENT - это режим по умолчанию». –  Matchu 20.01.2010 в 21:14
  • @Matchu: Да, ты прав, спасибо. Тем не менее PDO :: __ construct () генерирует исключение PDOException, если попытка подключения к запрашиваемой базе данных завершается с ошибкой. –  Alix Axel 20.01.2010 в 22:05
Показать остальные комментарии
0

Вы можете добавить атрибут один раз, когда вы подключаете mysql.

function connect($dsn, $user, $password){
    try {
        $dbh = new PDO($dsn, $user, $password, array(PDO::ATTR_ERRMODE => PDO::ERRMODE_WARNING));
    } catch (PDOException $e) {
        echo 'Connection failed: ' . $e->getMessage();
        exit;
    }
    }

Спасибо

    
ответ дан TomerM 02.02.2016 в 15:40
источник
  • Приятно! Как насчет PDO :: ERRMODE_EXCEPTION? –  Jens Törnell 02.02.2016 в 15:43
  • Тот же путь PDO :: ATTR_ERRMODE => PDO :: ERRMODE_EXCEPTION –  TomerM 02.02.2016 в 16:00
  • Не перехватывайте исключения, чтобы сообщить об этом. PHP будет делать это лучше. –  Your Common Sense 02.02.2016 в 16:33