16

我有一个使用 PDO 执行的插入语句。插入效果很好,但是如果出现错误,我希望它显示给用户。

我有下面的 try-catch 块。

try{ 
    $insertuser = $db->prepare('INSERT INTO `she_she`.`Persons` (`idnumber`,`addedby`,`firstname`, `middlename`, `surname`, `fullname`, `gender`, `birthdate`, `homelanguage`, `department`, `employeetype`, `employeestatus`) VALUES  (?,?,?,?,?,?,?,?,?,?,?,?)'); 
    $insertuser->execute(array($idnumber,$user,$firstname, $middlename, $surname, $fullname, $gender, $birthdate, $language, $department, $employmenttype, $personstatus));  
} 
catch(PDOException $exception){ 
    return $exception; 
} 

如果查询失败,或者假设是重复的 IDNumber,我希望将其显示给用户。

如果我只是尝试回显变量 $exception 它不起作用。

我想将 MySQL 错误返回给用户。

4

3 回答 3

27

默认情况下,PDO 不处于会显示错误的状态。您需要在数据库连接中提供以下内容

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

更多信息可以在这里看到

于 2012-10-19T18:20:13.597 回答
4

1.在您的数据库连接后添加 ERRMODE_EXCEPTION 模式:

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

2.而且您必须对所有 mysql 查询使用 try{} catch{} 方法。像这样:

try {
    $SQL = "DELETE FROM items WHERE item_id=:item_id";
    $m = $dbh->prepare($SQL);
    $m->bindParam(':item_id', $item_id, PDO::PARAM_INT);
    $m->execute();
    //success
    $return = "Your success message.";
}
catch (PDOException $e) {
    //error
    $return = "Your fail message: " . $e->getMessage();
}
于 2019-03-06T07:55:43.693 回答
1

你应该使用这个:

return $exception->getMessage();

请参阅异常类的文档页面:

http://www.php.net/manual/en/exception.getmessage.php

于 2012-10-19T14:49:04.163 回答