首页 >后端开发 >php教程 >如何将数组绑定到 PDO 查询中的 IN() 子句?

如何将数组绑定到 PDO 查询中的 IN() 子句?

Susan Sarandon
Susan Sarandon原创
2024-12-19 20:33:11118浏览

How Can I Bind an Array to an IN() Clause in a PDO Query?

数组值可以绑定到 PDO 查询中的 IN() 条件吗?

将值数组绑定到 IN()使用 PDO 的情况是可能的,但需要手动构建占位符。操作方法如下:

  1. 创建占位符: 构造与数组元素数量相对应的占位符字符串。例如,如果数组包含三个值,则占位符字符串将为“?,?”。
  2. 准备语句:使用 IN() 条件和构造的占位符准备 PDO 语句.
  3. 执行语句: 执行准备好的语句并将数组值作为参数传递。 PDO 将自动绑定并引用值。

这里是一个示例:

$ids = [1, 2, 3, 7, 8, 9];
$inQuery = str_repeat('?,', count($ids) - 1) . '?'; // ?,?,?,?,?,?

$stmt = $db->prepare("SELECT * FROM table WHERE id IN($inQuery)");
$stmt->execute($ids);

如果是命名占位符:

  1. 创建占位符序列: 创建与数组元素相对应的命名占位符序列,例如:id0,:id1,:id2.
  2. 收集值:使用占位符序列作为键将数组值收集到键值数组中。
  3. 准备并执行: 准备语句并执行,合并参数数组。

这是一个示例:

$ids = [1, 2, 3];
$in = "";
$i = 0; // external counter
foreach ($ids as $item) {
    $key = ":id" . $i++;
    $in .= ($in ? "," : "") . $key; // :id0,:id1,:id2
    $in_params[$key] = $item; // collect values
}

$sql = "SELECT * FROM table WHERE id IN ($in)";
$stmt = $db->prepare($sql);
$stmt->execute(array_merge(["foo" => "foo", "bar" => "bar"], $in_params));

以上是如何将数组绑定到 PDO 查询中的 IN() 子句?的详细内容。更多信息请关注PHP中文网其他相关文章!

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