找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 218|回复: 0
打印 上一主题 下一主题

PHP中PDO的错误处理

[复制链接]

2588

主题

2588

帖子

7694

积分

论坛元老

Rank: 8Rank: 8

积分
7694
跳转到指定楼层
楼主
发表于 2018-2-14 08:32:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            面向对象的方式
先看看如果连接错误等的处理,PHP中PDO的错误处理,使用面向对象的方式来处理:
[U]复制代码[/U] 代码如下:
getMessage() . "
";
 die();
}
?>

这里利用我们PHP 5面向对象的异常处理特征,如果里面有异常的话就初始化调用PDOException来初始化一个异常类。
PDOException异常类的属性结构:
[U]复制代码[/U] 代码如下:


这个异常处理类是集成PHP 5内置的异常处理类,我们简单的看一下PHP 5内置的异常处理类结构:
[U]复制代码[/U] 代码如下:


相应的,在代码中可以合适的调用 getFile() 和 getLine() 来进行错误定位,更方便的进行调试。
使用面向过程的方法
先看代码:
[U]复制代码[/U] 代码如下:
query("SELECT aa,bb,cc FROM foo");
if ($db->errorCode() != '00000'){
 print_r($db->errorInfo());
 exit;
}
$arr = $rs->fetchAll();
print_r($arr);
$db = null;
?>

PDO和PDOStatement对象有errorCode() 和 errorInfo() 方法,如果没有任何错误, errorCode() 返回的是: 00000 ,否则就会返回一些错误代码。errorInfo() 返回的一个数组,包括PHP定义的错误代码和MySQL的错误代码和错误信息,数组结构如下:
Array
(
 [0] => 42S22
 [1] => 1054
 [2] => Unknown column 'aaa' in 'field list'
)
每次执行查询以后,errorCode() 的结果都是最新的,所以我们可以很容易自己控制错误信息显示。
在使用PDO进行那个PHP和数据库开发过程中,如果再碰到错误咋办?按照上面的方式处理吧。
11.3.4 PDO的错误处理
PDO提供了两个获得程序中的错误信息的方法,一个是errorCode()方法;另一个是errorInfo()方法。
1.errorCode()方法
errorCode()方法用于获取在操作数据库句柄时所发生的错误代码,这些错误代码被称为SQLSTATE代码,该方法的语法格式如下:
01 string errorCode ( void ) errorCode()方法的返回值为一个SQLSTATE,SQLSTATE是由5个数字和字母组成的代码。下面是使用errorCode()方法的示例:
【程序11-17】光盘\code\11\pdo\errorCode.php
[U]复制代码[/U] 代码如下:
exec("update mytable set age=28 where id=1 ");//表mytable不存在
echo "errorCode为: ".$pdo->errorCode();
?>

上述代码输出的错误代码如图11-13所示。

2.errorInfo()方法
errorInfo()方法用于获得操作数据库句柄时所发生的错误信息,该方法的语法格式如下:
01 array errorInfo ( void ) errorInfo()方法的返回值为一个数组,该数组里面包含了相关的错误信息,使用errorInfo()方法的示例代码如下:
【程序11-18】光盘\code\11\pdo\errorInfo.php
[U]复制代码[/U] 代码如下:
exec("update mytable set age=28 where id=1 ");//表mytable不存在
echo "errorInfo为: ";
print_r($pdo->errorInfo());
?>

上面代码输出的错误信息如图11-14所示。

            
            
您可能感兴趣的文章:
  • php调用mysql存储过程
  • 用PHP调用Oracle存储过程的方法
  • PHP MSSQL 存储过程的方法
  • PHP PDO函数库详解
  • PHP5中使用PDO连接数据库的方法
  • php中在PDO中使用事务(Transaction)
  • php存储过程调用实例代码
  • 基于Php mysql存储过程的详解
  • php中mysql连接方式PDO使用详解
  • PHP使用PDO调用mssql存储过程的方法示例
  • PHP基于PDO调用sqlserver存储过程通用方法【基于Yii框架】
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端