【问题标题】:Convert PHP while loop to use PDO将 PHP while 循环转换为使用 PDO
【发布时间】:2011-10-25 23:40:33
【问题描述】:

我目前正在通过切换到 PDO 来更新我的应用。我有以下代码:

$stmt = $db->prepare("select * from `product` where productid in (:productidLst)");
$stmt->bindParam(":productidLst",$productidLst, PDO::PARAM_INT);
$stmt->execute();

上述代码之后的 var $productidLst 是 1,2 我想使用与此等效的 PDO:

while($rs=mysql_fetch_assoc($res)){
    $rs['qty']=$_SESSION['basket'][$rs['productid']];
    $rs['total'] += $rs['qty']*$rs['price'];
    $total += $rs['total'];
    $a[] = $rs;
}

我已经尝试了许多组合,但都没有成功,因此我们将不胜感激(在第二个代码块中 $res 是 sql)。其次,我将参数 $productidLst 设置为 INT 这是正确的还是应该是字符串?

--------更新 1------------- --------------------------

我已经尝试了以下代码:

$stmt = $db->prepare("select * from `product` where productid in (:productidLst)");
foreach ($stmt->execute(array(':productidLst' => $productidLst)) as $row) 
{
    $total += $row['total'];
}

返回:foreach() 错误提供的参数无效

【问题讨论】:

标签: php sql pdo


【解决方案1】:

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 将返回,你猜对了,一个关联的数据数组。

在功能上,foreachwhile 实现是等效的。从概念上讲,foreach 更合适,因为while 循环具有在静态条件成立时循环的含义,而foreach 循环遍历集合的元素。阅读“Differences between a while loop and a for loop in PHP?”了解部分内容。

请务必阅读php.net reference on PDO

【讨论】:

  • 您好,感谢您的回复,我仍在苦苦挣扎,我不断收到:为 foreach() 提供的参数无效:。有关我正在使用的代码,请参阅更新 1 部分下的原始帖子。 (注意,为了便于阅读,我稍微简化了 while 循环中的代码)
  • @outis 我只是自己编辑了它,并进行了适当的代码更改和解释。
  • @Charles:之前的代码编辑有什么不当之处? PDOStatement 实现了Traversable,默认获取模式为PDO::FETCH_BOTH。 Rob 的观点是 PHP 手册有一个基本回答 Dino 问题的示例。从foreach 切换到while 有损这一点。
  • @outis 那是我的错误,我不知道PDOStatementTraversable。如果你愿意,你可以恢复我的编辑。我个人更喜欢这种方法,但每个人都有自己的想法。感谢您提供有关Traversable 的信息。
  • @Charles:让我们将两者结合起来。
【解决方案2】:

您应该使用PDOStatement::fetch() 来获取行。它以数字方式和关联方式获取(默认情况下)。你也可以改变它。

使用您的代码:

while($rs=$stmt->fetch()){
    $rs['qty']=$_SESSION['basket'][$rs['productid']];
    $rs['total'] += $rs['qty']*$rs['price'];
    $total += $rs['total'];
    $a[] = $rs;
}

Manual Reference.

【讨论】:

    猜你喜欢
    • 2010-11-19
    • 2015-02-16
    • 1970-01-01
    • 1970-01-01
    • 2017-02-14
    • 2014-06-18
    • 2021-08-29
    • 2014-12-11
    • 2018-02-22
    相关资源
    最近更新 更多