当前位置:首页 > PHP教程 > php应用 > 列表

php实现的PDO异常处理操作分析

发布:smiling 来源: PHP粉丝网  添加日期:2021-11-03 14:34:27 浏览: 评论:0 

本文实例讲述了php实现的PDO异常处理操作,分享给大家供大家参考,具体如下:

异常处理:

PHP:默认为直接报错

MYSQL:默认为静默模式,错就错,不报错

PDO:默认为静默模式,错就错,不报错

以前,当PHP碰到错误的时候,会直接报错,错误处理会变得相当麻烦。后来,当错误发生之后,会将错误信息不再直接输出,放到一个类的对象里(PDOException)

要使用PDO异常处理,必须满足两个条件

1、需要将错误处理模式变成异常模式

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

2、所有可能出错的语句都必须放到错误捕捉语句块里

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

例如:

  1. try{ 
  2.   //连接认证 
  3.   $pdo = new PDO('mysql:host=localhost;dbname=project','root','root'); 
  4.   //设置错误处理模式 
  5.   $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); 
  6.   //组织SQL 
  7.   $sql"update pro_student set s_age = 123 where s_id = 20"
  8.   $res = $pdo->exec($sql); 
  9. }catch(PDOException $e){ 
  10.   //var_dump($e); 
  11.   //告诉用户在哪个文件的哪一行出现了什么样的错误 
  12.   echo '出现异常:<br/>'
  13.   echo '错误出现的位置:' . $e->getFile() . $e->getLine() . '<br/>'
  14.   echo '错误原因:' . $e->getMessage(); 
  15.   var_dump($e->getTrace());//获取完整的错误数据 
  16.   exit

有的时候,如果数据执行没有任何错误,但是就是不符合指定的业务逻辑,一旦出现业务逻辑错误,异常是没有办法捕捉(异常只捕捉语法错误),一般认为的去通过判断语句的执行(结果),主动抛出异常,从而结束错误程序的运行。

语法:throw new PDOException;

  1. $sql = "select * from pro_student where s_id = 20"
  2. $stmt = $pdo->query($sql); 
  3. if($stmt->fetchColumn(4) > 100) throw new PDOException; //抛出异常,立马跳转到catch语句块 
  4. else
  5.   echo '没有问题'
  6. }

Tags: php异常处理 PDO异常处理

分享到: