php5 pdo数据库类用法实例详解

发布时间:2020-09-29编辑:脚本学堂
本文详细介绍了php5中pdo数据库类的用法,通过实例学习掌握php pdo的用法,有需要的朋友参考下。
本节是 php5 pdo数据库类用法实例详解 第二部分的内容。
使用setfetchmode方法来设置获取结果集的返回值的类型,同样类型还有:
 

复制代码 代码示例:
pdo::fetch_assoc -- 关联数组形式
pdo::fetch_num -- 数字索引数组形式
pdo::fetch_both -- 两者数组形式都有,这是缺省的
pdo::fetch_obj -- 按照对象的形式,类似于以前的 mysql_fetch_object()

当然,一般情况下 是使用pdo::fetch_assoc,具体使用什么,按照你自己的需要,其他获取类型参考手册。

除了上面这种获取数据的方式,还有这种:
 

复制代码 代码示例:
<?php
$rs = $db->prepare("select * from foo");
$rs->execute();
while($row = $rs->fetch()){
    print_r($row);
}
?>
 

其实差不多啦。如果你想获取指定记录里一个字段结果的话,可以使用 pdostatement::fetchcolumn():
 

复制代码 代码示例:
<?php
$rs = $db->query("select count(*) from foo");
$col = $rs->fetchcolumn();
echo $col;
?>

一般使用fetchcolumn()来进行count统计或者某些只需要单字段的记录很好操作。
 
总结以上操作:

查询操作主要是pdo::query()、pdo::exec()、pdo::prepare()。pdo::query()主要是用于有记录结果返回的操作,特别是select操作,pdo::exec()主要是针对没有结果集合返回的操作,比如insert、update、delete等操作,它返回的结果是当前操作影响的列数。pdo::prepare()主要是预处理操作,需要通过$rs->execute()来执行预处理里面的sql语句,这个方法可以绑定参数,功能比较强大,不是本文能够简单说明白的,大家可以参考手册和其他文档。

获取结果集操作主要是:pdostatement::fetchcolumn()、pdostatement::fetch()、pdostatement::fetchall()。pdostatement::fetchcolumn() 是获取结果指定第一条记录的某个字段,缺省是第一个字段。pdostatement::fetch() 是用来获取一条记录,pdostatement::fetchall()是获取所有记录集到一个中,获取结果可以通过pdostatement::setfetchmode来设置需要结果集合的类型。

另外有两个周边的操作,一个是pdo::lastinsertid()和pdostatement::rowcount()。pdo::lastinsertid()是返回上次插入操作,主键列类型是自增的最后的自增id。pdostatement::rowcount()主要是用于pdo::query()和pdo::prepare()进行delete、insert、update操作影响的结果集,对pdo::exec()方法和select操作无效。

【错误处理】

如果程序中碰到错误咋办? 这里描述pdo类的错误信息和异常处理。
1. 面向对象的方式
先看看如果连接错误等的处理,使用面向对象的方式来处理:
 

复制代码 代码示例:
<?php
try {
   $db = new pdo('mysql:host=localhost;dbname=test', $user, $pass);
   $db = null;
} catch (pdoexception $e) {
   print "error: " . $e->getmessage() . "<br/>";
   die();
}
?>

这里利用 php 5面向对象的异常处理特征,如果里面有异常的话就初始化调用pdoexception来初始化一个异常类。
pdoexception异常类的属性结构:
 

复制代码 代码示例:
<?php
class pdoexception extends exception
{
    public $errorinfo = null;  // 错误信息,可以调用 pdo::errorinfo() 或 pdostatement::errorinfo()来访问
    protected $message;    // 异常信息,可以试用 exception::getmessage() 来访问
    protected $code;             // sql状态错误代码,可以使用 exception::getcode() 来访问
}
?>

 这个异常处理类是集成php 5内置的异常处理类, 简单的看一下php 5内置的异常处理类结构:
 

复制代码 代码示例:

<?php
class exception
{
    // 属性
    protected $message = 'unknown exception';   // 异常信息
    protected $code = 0;                        // 用户自定义异常代码
    protected $file;                            // 发生异常的文件名
    protected $line;                            // 发生异常的代码行号

    // 方法
    final function getmessage();                // 返回异常信息
    final function getcode();                   // 返回异常代码
    final function getfile();                   // 返回发生异常的文件名
    final function getline();                   // 返回发生异常的代码行号
    final function gettrace();                  // backtrace() 数组
    final function gettraceasstring();          // 已格成化成字符串的 gettrace() 信息
}
?>

相应的,在代码中可以合适的调用 getfile() 和 getline() 来进行错误定位,更方便的进行调试。

2. 使用面向过程的方法
先看代码:
 

复制代码 代码示例:
<?
$db = new pdo('mysql:host=localhost;dbname=test', $user, $pass);
$rs = $db->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() 的结果都是最新的,所以 可以很容易自己控制错误信息显示。

以上介绍了php中pdo的用法,希望对大家有所帮助。