异常处理:mysql
PHP:默认为直接报错sql
MYSQL:默认为静默模式,错就错,不报错fetch
PDO:默认为静默模式,错就错,不报错spa
之前,当PHP碰到错误的时候,会直接报错,错误处理会变得至关麻烦。后来,当错误发生以后,会将错误信息再也不直接输出,放到一个类的对象里(PDOException)code
要使用PDO异常处理,必须知足两个条件对象
一、须要将错误处理模式变成异常模式blog
$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);pdo
二、全部可能出错的语句都必须放到错误捕捉语句块里get
try{it
//错误捕捉语句块
//凡有可能出现错误的语句都放在这
//一旦出错会当即进入catch语句,把全部的错误信息放到PDOexception $e里面
}catch(PDOExecption $e){
//将错误信息进行处理
}
例如:
try{ //链接认证 $pdo = new PDO('mysql:host=localhost;dbname=project','root','root'); //设置错误处理模式 $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); //组织SQL $sql= "update pro_student set s_age = 123 where s_id = 20"; $res = $pdo->exec($sql); }catch(PDOException $e){ //var_dump($e); //告诉用户在哪一个文件的哪一行出现了什么样的错误 echo '出现异常:<br/>'; echo '错误出现的位置:' . $e->getFile() . $e->getLine() . '<br/>'; echo '错误缘由:' . $e->getMessage(); var_dump($e->getTrace());//获取完整的错误数据 exit; }
有的时候,若是数据执行没有任何错误,可是就是不符合指定的业务逻辑。一旦出现业务逻辑错误,异常是没有办法捕捉(异常只捕捉语法错误),通常认为的去经过判断语句的执行(结果),主动抛出异常,从而结束错误程序的运行。
语法:throw new PDOException;
$sql = "select * from pro_student where s_id = 20"; $stmt = $pdo->query($sql); if($stmt->fetchColumn(4) > 100) throw new PDOException; //抛出异常,立马跳转到catch语句块 else{ echo '没有问题'; }