예외 처리:
PHP: 기본값은 오류를 직접 보고하는 것입니다.
MYSQL: 기본값은 자동 모드이며, 오류가 발생하면 오류가 보고되지 않습니다.
PDO: 기본값은 자동 모드입니다. 실수하면 오류를 보고하지 마세요.
과거에는 PHP에서 오류가 발생하면 직접 오류를 보고했고, 오류 처리는 매우 번거로울 것입니다. 나중에 오류가 발생하면 오류 정보가 더 이상 직접 출력되지 않고 클래스 객체(PDOException)에 배치됩니다.
pdo 예외 처리 설정:
Set PDO::ATTR_ERRMODE, 다음 세 가지 값:
PDO::ERRMODE_SILENT: 기본 모드는 오류를 적극적으로 보고하지 않습니다. $pdo->errorInfo() 형식으로 오류 정보를 적극적으로 얻어야 합니다.
PDO::ERRMODE_WARNING: E_WARNING 오류 발생, 사전에 오류 보고
PDO::ERRMODE_EXCEPTION: 사전에 예외 발생, try{}cath(){}를 사용하여 오류 정보를 출력해야 합니다.
예:
방법 1:
<?php //默认是不提示的 需要用 errorCode() errorInfo(); try{ $pdo = new PDO("mysql:host=localhost;dbname=jikexueyuan","root",""); //下面这句是默认设置,有无均可 $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_SILENT); }catch(PDOException $e){ die("数据库连接失败".$e->getMessage()); } $sql = "insert into stuu values(null,'jike','w',55)"; $res = $pdo->exec($sql); if($res){ echo "OK"; }else{ echo $pdo->errorCode(); print_r($pdo->errorInfo()); }
방법 2:
<?php try{ $pdo = new PDO("mysql:host=localhost;dbname=jikexueyuan","root",""); //主动以警告的形式报错 $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_WARNING); }catch(PDOException $e){ die("数据库连接失败".$e->getMessage()); } $sql = "insert into stuu values(null,'jike','w',55)"; //若有错误直接在浏览器页面中显示错误信息 $res = $pdo->exec($sql);
방법 3:
<?php try{ $pdo = new PDO("mysql:host=localhost;dbname=jikexueyuan","root",""); //主动抛出异常 $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION ); }catch(PDOException $e){ die("数据库连接失败".$e->getMessage()); } $sql = "insert into stuu values(null,'jike','w',55)"; //用try{}catch(){}抓取异常 try{ $res = $pdo->exec($sql); }catch(PDOException $e){ echo $e->getMessage(); }