码迷,mamicode.com
首页 > Web开发 > 详细

php -- PDO异常处理

时间:2015-07-24 15:42:39      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:

异常处理:

  PHP:默认为直接报错

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

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

 

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

 

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

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

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

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

  try{

         //错误捕捉语句块

         //凡是有可能出现错误的语句都放在这

         //一旦出错会立即进入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 ‘没有问题‘;
        }

 

php -- PDO异常处理

标签:

原文地址:http://www.cnblogs.com/hf8051/p/4673523.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!