栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

将PHP while循环转换为使用PDO

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

将PHP while循环转换为使用PDO

PHP手册中的标准文档通常会很有帮助。PHP手册PDO
Details中
有一个使用PDO执行for循环的示例。

function getFruit($conn) {    $sql = 'SELECt name, color, calories FROM fruit ORDER BY name';    foreach ($conn->query($sql) as $row) {        print $row['name'] . "t";        print $row['color'] . "t";        print $row['calories'] . "n";    }}

进行一些更改,就可以使该示例使用准备好的语句。

function getFruit($conn) {    $query = $conn->prepare('SELECt name, color, calories FROM fruit WHERe kind=:kind ORDER BY name');    $query->execute(array(':kind' => 'drupe'));    // alternatively you could use PDOStatement::fetchAll() and get rid of the loop    // this is dependent upon the design of your app    foreach ($query as $row) {        print $row['name'] . "t";        print $row['color'] . "t";        print $row['calories'] . "n";    }}

您还可以使用

while
循环并
PDOStatement::fetch
获取每一行。

function getFruit($conn) {    $query = $conn->prepare('SELECt name, color, calories FROM fruit WHERe kind=:kind ORDER BY name');    $query->execute(array(':kind' => 'drupe'));    // alternatively you could use PDOStatement::fetchAll() and get rid of the loop    // this is dependent upon the design of your app    while ($row = $query->fetch(PDO::FETCH_ASSOC)) {        print $row['name'] . "t";        print $row['color'] . "t";        print $row['calories'] . "n";    }}

PHP手册在提供创建后两个版本的所有必要信息方面仍然非常有帮助。

最新版本的解释:假设

$conn
是有效的PDO对象。 如果成功,失败
基于您的错误处理的异常,则
$conn->prepare($sql)
返回一个
PDOStatement
对象。因此,假设成功,我们实际上希望从对象中获取数据。我们可以循环使用,也可以根据您的应用获取数据。您猜对了,传递类常量将返回一个关联的数据数组。
false

__
$query->fetch()
$query->fetchAll()
PDO::FETCH_ASSOC

在功能上,

foreach
while
实现是等效的。从概念上讲,a
foreach
更合适,因为
while
循环具有在静态条件成立时进行循环的含义,而
foreach
在集合的元素上进行循环。

请务必阅读PDO上的php.net参考



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/414820.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号