Как предотвратить отображение ошибки PDO? - PullRequest
3 голосов
/ 28 апреля 2011

Когда возникает ошибка из PDO execute (), по какой-то причине она выводит ошибку?

Как мне предотвратить это ... Я хотел бы сохранить ошибку в $ data ['error']

if (!$query->execute()) {
             $data['success'] = 'false';
             echo json_encode($data);
             return;
}

Из журнала консоли:

<br />
<b>Warning</b>:  PDOStatement::execute() [<a href='pdostatement.execute'>pdostatement.execute</a>]: SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens in <b>C:\wamp\www\site\application\controller\ContactController.php</b> on line <b>101</b><br />
{"success":"false"}

Ответы [ 3 ]

4 голосов
/ 28 апреля 2011

Чтобы объединить то, что говорят два других разработчика, сначала настройте PDO на использование исключений вместо ошибок php:

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

Затем используйте блок try ... catch для обработки любой ошибки.

$db->beginTransaction();
try{
  /* Do your database things here */
}
catch(Exception $e){
  $db->rollBack();
  return;
}
$db->commit();
return;

Вы также можете настроить свой собственный обработчик ошибок php, который можно использовать для регистрации всех ошибок в файле и ничего не отображать. Смотрите документацию php: http://php.net/manual/en/function.set-error-handler.php

3 голосов
/ 28 апреля 2011

Вы можете изменить режим ошибки по своему вкусу, например ::10000

$conn = new PDO(...);
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

Пожалуйста, найдите дополнительную ссылку на http://uk.php.net/manual/en/pdo.error-handling.php

0 голосов
/ 28 апреля 2011

Используйте PHP try catch

try{
     doPDO();
}
catch (PDOException $err) {
     echo "pdo failed";
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...