首頁 >後端開發 >php教程 >如何使用佔位符 SQL 查詢將陣列傳遞給 WHERE 子句?

如何使用佔位符 SQL 查詢將陣列傳遞給 WHERE 子句?

Barbara Streisand
Barbara Streisand原創
2024-12-18 09:52:13390瀏覽

How Can I Use Placeholder SQL Queries to Pass Arrays to WHERE Clauses?

使用佔位符SQL 查詢將陣列傳遞給WHERE 子句

在SQL 查詢中處理陣列時,特別是使用WHERE 子句時,它會變成有必要找到一種方法將數組的值合併到查詢字串中。提供的 ID 陣列 ($gallery) 需要一個在 WHERE 子句中有效使用這些值的查詢。

一種解決方案涉及使用佔位符 SQL 查詢。請依照以下步驟操作:

1.定義佔位符字串:

$placeholder = join(',', array_fill(0, count($galleries), '?'));

這將建立一個用逗號分隔問號的字串,表示陣列值的佔位符。在我們的範例中,佔位符字串為「?,,?」。

2。準備查詢字串:

$query = "SELECT * FROM galleries WHERE id IN ({$placeholder})";

查詢字串使用 IN 運算子和占位符字串將陣列值合併到 WHERE 子句中。

3.綁定陣列值:

使用準備好的語句,將陣列值綁定到佔位符:

$stmt = $conn->prepare($query);
$stmt->bind_param(str_repeat('i', count($galleries)), ...$galleries);

這會將陣列元素綁定到準備好的語句中的佔位符。

4。執行查詢:

$stmt->execute();

執行準備好的語句,有效地使用 WHERE 子句中的陣列值。

以上是如何使用佔位符 SQL 查詢將陣列傳遞給 WHERE 子句?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn