PHP PDOStatement::fetchAll讲解


Posted in PHP onJanuary 31, 2019

PDOStatement::fetchAll

PDOStatement::fetchAll — 返回一个包含结果集中所有行的数组(PHP 5 >= 5.1.0, PECL pdo >= 0.1.0)

说明

语法

array PDOStatement::fetchAll ([ int $fetch_style [, mixed $fetch_argument [, array $ctor_args = array() ]]] )

参数

fetch_style

  • 控制下一行如何返回给调用者。此值必须是 PDO::FETCH_* 系列常量中的一个,缺省为 PDO::ATTR_DEFAULT_FETCH_MODE 的值 (默认为 PDO::FETCH_BOTH )。
  • 想要返回一个包含结果集中单独一列所有值的数组,需要指定 PDO::FETCH_COLUMN 。通过指定 column-index 参数获取想要的列。
  • 想要获取结果集中单独一列的唯一值,需要将 PDO::FETCH_COLUMN 和 PDO::FETCH_UNIQUE 按位或。
  • 想要返回一个根据指定列把值分组后的关联数组,需要将 PDO::FETCH_COLUMN 和 PDO::FETCH_GROUP 按位或。

fetch_argument

根据 fetch_style 参数的值,此参数有不同的意义:

  • PDO::FETCH_COLUMN :返回指定以0开始索引的列。
  • PDO::FETCH_CLASS :返回指定类的实例,映射每行的列到类中对应的属性名。
  • PDO::FETCH_FUNC :将每行的列作为参数传递给指定的函数,并返回调用函数后的结果。

ctor_args

当 fetch_style 参数为 PDO::FETCH_CLASS 时,自定义类的构造函数的参数。

返回值

PDOStatement::fetchAll()返回一个包含结果集中所有剩余行的数组。此数组的每一行要么是一个列值的数组,要么是属性对应每个列名的一个对象。

使用此方法获取大结果集将导致系统负担加重且可能占用大量网络资源。与其取回所有数据后用PHP来操作,倒不如考虑使用数据库服务来处理结果集。例如,在取回数据并通过PHP处理前,在SQL 中使用 WHERE 和 ORDER BY 子句来限定结果。

实例

获取结果集中所有剩余的行

<?php
$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
/* 获取结果集中所有剩余的行 */
print("Fetch all of the remaining rows in the result set:\n");
$result = $sth->fetchAll();
print_r($result);
?>

以上实例的输出为:

Fetch all of the remaining rows in the result set:
Array
(
  [0] => Array
    (
      [NAME] => pear
      [0] => pear
      [COLOUR] => green
      [1] => green
    )
  [1] => Array
    (
      [NAME] => watermelon
      [0] => watermelon
      [COLOUR] => pink
      [1] => pink
    )
)

获取结果集中单独一列的所有值

下面例子演示了如何从一个结果集中返回单独一列所有的值,尽管 SQL 语句自身可能返回每行多列。

<?php
$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
/* 获取第一列所有值 */
$result = $sth->fetchAll(PDO::FETCH_COLUMN, 0);
var_dump($result);
?>

以上实例的输出为:

Array(3)
(
  [0] =>
  string(5) => apple
  [1] =>
  string(4) => pear
  [2] =>
  string(10) => watermelon
)

根据单独的一列把所有值分组

下面例子演示了如何返回一个根据结果集中指定列的值分组的关联数组。该数组包含三个键:返回的 apple 和 pear 数组包含了两种不同的颜色,而返回的 watermelon 数组仅包含一种颜色。

<?php
$insert = $dbh->prepare("INSERT INTO fruit(name, colour) VALUES (?, ?)");
$insert->execute(array('apple', 'green'));
$insert->execute(array('pear', 'yellow'));
$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
/* 根据第一列分组 */
var_dump($sth->fetchAll(PDO::FETCH_COLUMN|PDO::FETCH_GROUP));
?>

以上实例的输出为:

array(3) {
 ["apple"]=>
 array(2) {
  [0]=>
  string(5) "green"
  [1]=>
  string(3) "red"
 }
 ["pear"]=>
 array(2) {
  [0]=>
  string(5) "green"
  [1]=>
  string(6) "yellow"
 }
 ["watermelon"]=>
 array(1) {
  [0]=>
  string(5) "green"
 }
}

每行结果实例化一个类

下面列子演示了 PDO::FETCH_CLASS 获取风格的行为。

<?php
class fruit {
  public $name;
  public $colour;
}
$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
$result = $sth->fetchAll(PDO::FETCH_CLASS, "fruit");
var_dump($result);
?>

以上实例的输出为:

array(3) {
 [0]=>
 object(fruit)#1 (2) {
  ["name"]=>
  string(5) "apple"
  ["colour"]=>
  string(5) "green"
 }
 [1]=>
 object(fruit)#2 (2) {
  ["name"]=>
  string(4) "pear"
  ["colour"]=>
  string(6) "yellow"
 }
 [2]=>
 object(fruit)#3 (2) {
  ["name"]=>
  string(10) "watermelon"
  ["colour"]=>
  string(4) "pink"
 }
}

每行调用一次函数

下面列子演示了 PDO::FETCH_FUNC 获取风格的行为。

<?php
function fruit($name, $colour) {
  return "{$name}: {$colour}";
}
$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
$result = $sth->fetchAll(PDO::FETCH_FUNC, "fruit");
var_dump($result);
?>

以上实例的输出为:

array(3) {
 [0]=>
 string(12) "apple: green"
 [1]=>
 string(12) "pear: yellow"
 [2]=>
 string(16) "watermelon: pink"
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。如果你想了解更多相关内容请查看下面相关链接

PHP 相关文章推荐
PHP安全配置
Oct 09 PHP
php.ini 中文版
Oct 28 PHP
服务器web工具 php环境下
Dec 29 PHP
php基于curl扩展制作跨平台的restfule 接口
May 11 PHP
php中 ob_start等函数截取标准输出的方法
Jun 22 PHP
在Windows系统下使用PHP生成Word文档的教程
Jul 03 PHP
PHP使用stream_context_create()模拟POST/GET请求的方法
Apr 02 PHP
ThinkPHP使用Ueditor的方法详解
May 20 PHP
PHP的时间戳与具体时间转化的简单实现
Jun 13 PHP
PHP实现的基于单向链表解决约瑟夫环问题示例
Sep 30 PHP
PHP 实现手机端APP支付宝支付功能
Jun 07 PHP
Laravel框架表单验证操作实例分析
Sep 30 PHP
PHP PDOStatement::fetch讲解
Jan 31 #PHP
PHP PDOStatement::execute讲解
Jan 31 #PHP
PHP PDOStatement::errorInfo讲解
Jan 31 #PHP
PHP PDOStatement::errorCode讲解
Jan 31 #PHP
PHP PDOStatement::columnCount讲解
Jan 30 #PHP
PHP PDOStatement::closeCursor讲解
Jan 30 #PHP
PHP PDOStatement::debugDumpParams讲解
Jan 30 #PHP
You might like
php minixml详解
2008/07/19 PHP
PHP 采集程序 常用函数
2008/12/18 PHP
PHP中foreach循环中使用引用要注意的地方
2011/01/02 PHP
PHP写的简单数字验证码实例
2017/05/23 PHP
laravel5 Eloquent 实现事务方式
2019/10/21 PHP
jQuery lazyload 的重复加载错误以及修复方法
2010/11/19 Javascript
jquery ajax 同步异步的执行 return值不能取得的解决方案
2012/01/08 Javascript
JS两种定义方式的区别、内部原理
2013/11/21 Javascript
jQuery 事件的命名空间简单了解
2013/11/22 Javascript
解析页面加载与js函数的执行 onload or ready
2013/12/12 Javascript
jQuery实现获取table表格第一列值的方法
2016/03/01 Javascript
关于使用js算总价的问题
2017/06/23 Javascript
认识jQuery的Promise的具体使用方法
2017/10/10 jQuery
微信小程序获取手机网络状态的方法【附源码下载】
2017/12/08 Javascript
vue.js实现插入数值与表达式的方法分析
2018/07/06 Javascript
JS实现求字符串中出现最多次数的字符和次数示例
2019/07/05 Javascript
Vue编程式跳转的实例代码详解
2019/07/10 Javascript
微信小程序 组件的外部样式externalClasses使用详解
2019/09/06 Javascript
使用element-ui +Vue 解决 table 里包含表单验证的问题
2020/07/17 Javascript
对于Python的框架中一些会话程序的管理
2015/04/20 Python
Win10下Python环境搭建与配置教程
2016/11/18 Python
Python实现二分查找与bisect模块详解
2017/01/13 Python
Python 实现字符串中指定位置插入一个字符
2018/05/02 Python
python配置grpc环境
2019/01/01 Python
python爬取内容存入Excel实例
2019/02/20 Python
Pyinstaller 打包exe教程及问题解决
2019/08/16 Python
如何运行带参数的python脚本
2019/11/15 Python
nginx搭建基于python的web环境的实现步骤
2020/01/03 Python
Django 实现对已存在的model进行更改
2020/03/28 Python
创建索引时需要注意的事项
2013/05/13 面试题
如何从一个文件档案的尾端新增记录
2016/12/02 面试题
2014银行领导班子群众路线对照检查材料思想汇报
2014/09/17 职场文书
出国留学单位推荐信
2015/03/26 职场文书
大国崛起观后感
2015/06/02 职场文书
Python使用protobuf序列化和反序列化的实现
2021/05/19 Python
postgreSQL数据库基础知识介绍
2022/04/12 PostgreSQL