zoukankan      html  css  js  c++  java
  • php -- PDO异常处理

    异常处理:

      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 '没有问题';
            }
  • 相关阅读:
    一种新的语法研究方法论——构式语法(construction grammar)理论
    男士健身篇
    !!! TCP实现P2P通信、TCP穿越NAT的方法、TCP打洞
    新手怎样学习Flash及as脚本编程? [复制链接]
    UDP穿越NAT原理
    一周七天英语怎么说
    !! 使用正则表达式匹配嵌套Html标签
    优秀老板的特征李开复微博
    搜狐超越新浪给创业者的两个启示:不断+耐心布局
    成大事必备九种手段(没有手段,你永远吃不到成功的甜果)
  • 原文地址:https://www.cnblogs.com/hf8051/p/4673523.html
Copyright © 2011-2022 走看看