在PDO 中實作LIKE 查詢
在PDO 查詢中使用LIKE 運算子時,必須確保正確的語法來實現所需的搜尋結果。在提供的查詢中,$query 字串中 % 符號的位置不正確導致了這個問題。
語法修正
修改後的查詢應包含% 符號在$params 數組中,而不是在查詢字串中:
$query = "SELECT * FROM tbl WHERE address LIKE ? OR address LIKE ?"; $params = array("%$var1%", "%$var2%");
此修改可確保LIKE 運算子在$var1 和$var2 變量,同時在準備好的語句中轉義它們。
說明
在 PDO 中,準備好的語句使用佔位符 (?) 來表示動態值。執行查詢時,$params 陣列提供對應的值來取代佔位符。在原始查詢中,% 符號被放置在 $query 字串中,這導致 PDO 將它們視為文字字元。
透過將 % 符號移到 $params 陣列中,您表明它們是一部分正在搜尋的動態值的一部分,而不是查詢語法本身的一部分。
以上是如何在 PDO 準備語句中正確使用 LIKE 運算子?的詳細內容。更多資訊請關注PHP中文網其他相關文章!