使用佔位符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中文網其他相關文章!