pdo mysql fetchall_PDO中获取结果集之fetchAll()方法详解

本文详细解析PDO的fetchAll()方法,用于一次性获取数据库查询结果集的所有行,返回二维数组。讨论了fetch_style参数的不同选项,如FETCH_ASSOC、FETCH_NUM等,并提供了示例代码展示如何使用fetchAll()从MySQL数据库中获取并输出数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

PDO中获取结果集之fetchAll()方法详解

fetchAll()方法是获取结果集中的所有行,返回一个包含结果集中所有行的二进制数组!

那么在上一篇《PDO中获取结果集之fetch()方法详解》中,我们介绍了fetch()方法获取结果集,我们今天将要介绍的fetchAll()方法与上一个方法fetch()类似,但是该方法只需要调用一次就可以获取结果集中的所有行,并赋给返回的数组(二维)。

fetchAll()方法的语法格式如下:array PDOStatement::fetchAll ([ int $fetch_style [, mixed $fetch_argument [, array $ctor_args = array() ]]] )

参数 fetch_style:控制结果集中数据的返回方式,可选值如下表:值说 明

PDO::FETCH_ASSOC关联数组形式

PDO::FETCH_NUM数字索引数组形式

PDO::FETCH_BOTH两者数组形式都有,这是默认的

PDO::FETCH_OBJ按照对象的形式,类似于以前的mysql_fetch_object()

PDO::FETCH_BOUND以布尔值的形式返回结果,同时将获取的列值赋给bindParam()方法中指定的变量

PDO::FETCH_LAZY以关联数组、数字索引数组和对象3种形式返回结果。

参数 column_index:字段的索引!

其返回值是一个包含结果集中所有数据的二维数组。

下面我们通过 fetchAll()方法获取结果集中的所有行,并且通过 for 语句读取二维数组中的数据,完成数据库中数据的循环输出,具体步骤如下:

首先创建php文件,通过 PDO 连接MySQL 数据库,然后定义 SELECT查询语句,应用 prepare()和execute()方法执行查询操作,接着,通过fetchAll()方法返回结果集中的所有行,最后使用 for 语句完成结果集中所有数据的循环输出,代码如下:<?php

header("Content-Type:text/html; charset=utf-8"); //设置页面的编码格式

$dbms = "mysql"; // 数据库的类型

$dbName ="php_cn"; //使用的数据库名称

$user = "root"; //使用的数据库用户名

$pwd = "root"; //使用的数据库密码

$host = "localhost"; //使用的主机名称

$dsn = "$dbms:host=$host;dbname=$dbName";

try{

$pdo=new PDO($dsn,$user,$pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo

$query="select * from user";//需要执行的sql语句

$res=$pdo->prepare($query);//准备查询语句

$res->execute(); //执行查询语句,并返回结果集

?>

id用户名密码

$result=$res->fetchAll(PDO::FETCH_ASSOC) ; // 获取结果集中的所有数据。

for ($i=0;$i

?>

<?php echo $result[$i]['id'];?><?php echo $result[$i]['username'];?><?php echo $result[$i]['password'];?>

}

}catch(Exception $e){

die("Error!:".$e->getMessage().'
');

}

?>

输出的结果如下:

f100331dc1b490f2cd0b261fd80f5e5c.png

关于PDO中获取结果集的fetchAll()方法我们就先介绍到这里,该方法跟我们之前介绍的fetch()方法类似,大家千万不要用错了,下一篇文章我们为大家接续介绍PDO中获取结果集的第三种方法,fetchColumn()方法,具体请阅读《PDO中获取结果集之fetchColumn()方法详解》!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值