当然,一般情况下 是使用pdo::fetch_assoc,具体使用什么,按照你自己的需要,其他获取类型参考手册。
除了上面这种获取数据的方式,还有这种:
其实差不多啦。如果你想获取指定记录里一个字段结果的话,可以使用 pdostatement::fetchcolumn():
一般使用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 5面向对象的异常处理特征,如果里面有异常的话就初始化调用pdoexception来初始化一个异常类。
pdoexception异常类的属性结构:
这个异常处理类是集成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. 使用面向过程的方法
先看代码:
pdo和pdostatement对象有errorcode() 和 errorinfo() 方法,如果没有任何错误, errorcode() 返回的是: 00000 ,否则就会返回一些错误代码。errorinfo() 返回的一个数组,包括php定义的错误代码和mysql的错误代码和错误信息,数组结构如下:
array
(
[0] => 42s22
[1] => 1054
[2] => unknown column 'aaa' in 'field list'
)
每次执行查询以后,errorcode() 的结果都是最新的,所以 可以很容易自己控制错误信息显示。
以上介绍了php中pdo的用法,希望对大家有所帮助。