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、所有可能出错的语句都必须放到错误捕捉语句块里
- 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 '没有问题';
- }
Tags: php异常处理 PDO异常处理
相关文章
- ·PHP异常处理(Exception)什么情况下使用?(2016-08-30)
- ·PHP基础之异常处理2——扩展 PHP 内置的异常处理类(2021-01-02)
- ·PHP基础之异常处理1——简单异常处理及嵌套异常(2021-01-02)
- ·分享一个php 的异常处理程序(2021-03-01)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)