带有“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中文网其他相关文章!