php实现PDO异常处理操作 结合实例形式分析原理

2018-12-2720:48:33后端程序开发Comments1,809 views字数 1130阅读模式
php实现的PDO异常处理操作,结合实例形式分析了pdo异常处理的相关原理、用法及操作注意事项。具体如下:

异常处理:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

PHP:默认为直接报错文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

MYSQL:默认为静默模式,错就错,不报错文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

PDO:默认为静默模式,错就错,不报错文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

以前,当PHP碰到错误的时候,会直接报错,错误处理会变得相当麻烦。后来,当错误发生之后,会将错误信息不再直接输出,放到一个类的对象里(PDOException)文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

要使用PDO异常处理,必须满足两个条件文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

1、需要将错误处理模式变成异常模式文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

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

2、所有可能出错的语句都必须放到错误捕捉语句块里文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

try{
   //错误捕捉语句块
   //凡是有可能出现错误的语句都放在这
   //一旦出错会立即进入catch语句,把所有的错误信息放到PDOexception $e里面
}catch(PDOExecption $e){
   //将错误信息进行处理
}

例如:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

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;
}

有的时候,如果数据执行没有任何错误,但是就是不符合指定的业务逻辑。一旦出现业务逻辑错误,异常是没有办法捕捉(异常只捕捉语法错误),一般认为的去通过判断语句的执行(结果),主动抛出异常,从而结束错误程序的运行。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

语法:throw new PDOException;文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html

$sql = "select * from pro_student where s_id = 20";
$stmt = $pdo->query($sql);
if($stmt->fetchColumn(4) > 100) throw new PDOException; //抛出异常,立马跳转到catch语句块
else{
  echo '没有问题';
}
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/9109.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/bc/9109.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定