首頁 >後端開發 >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