首页 >后端开发 >php教程 >如何在 PDO 查询中使用'WHERE...IN”子句有效删除记录?

如何在 PDO 查询中使用'WHERE...IN”子句有效删除记录?

Linda Hamilton
Linda Hamilton原创
2024-10-30 03:03:02533浏览

How to Effectively Delete Records with

带有“WHERE...IN”子句的 PDO 查询

使用 PHP 的 PDO 进行数据库访问时,构造“WHERE...IN” IN”查询可能具有挑战性。在本例中,目标是根据从表单获取的 ID 列表删除表中的记录。

原始查询

<code class="php">$query = "DELETE from `foo` WHERE `id` IN (:idlist)";
$st = $db->prepare($query);
$st->execute(array(':idlist' => $idlist));</code>

问题

此查询仅删除列表中的第一个 ID,由于逗号分隔符而丢弃剩余的 ID。

使用问号的解决方案

由于准备好的语句不能将值与控制流逻辑(逗号)混合,因此有必要为列表中的每个值使用一个占位符。这是通过创建逗号分隔的问号字符串并将各个 ID 绑定到它们来实现的。

<code class="php">$idlist = array('260','201','221','216','217','169','210','212','213');

$questionmarks = str_repeat("?,", count($idlist)-1) . "?";

$stmt = $dbh->prepare("DELETE FROM `foo` WHERE `id` IN ($questionmarks)");

foreach ($idlist as $id) {
    $stmt->bindParam($id);
}</code>

此方法需要循环遍历列表以顺序绑定每个 ID,确保所有记录都被删除为有意为之。

以上是如何在 PDO 查询中使用'WHERE...IN”子句有效删除记录?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn