使用PDO 準備語句執行帶通配符的SQL 查詢
在資料庫應用程式中執行模式比對查詢對於靈活的搜尋和資料擷取至關重要。本文介紹了在執行 MySQL 查詢時如何在 PHP 中有效地結合使用通配符和 PDO 預先準備語句。
挑戰:在預準備語句中使用通配符
使用預準備語句時,它提供了改進的安全性並防止SQL 注入漏洞,找到一個合併通配符(% 和_)進行模式匹配的解決方案可能具有挑戰性。本文將探討 PDO 準備語句中通配符的成功實現。
解決方案:bindValue 和 bindParam
在準備語句中成功使用通配符的關鍵在於選擇適當的綁定方法。有以下兩個綁定選項可用:
使用範例:bindValue()
以下程式碼片段示範如何使用bindValue()成功執行查詢:
<code class="php">$stmt = $dbh->prepare("SELECT * FROM `gc_users` WHERE `name` LIKE :name"); $stmt->bindValue(':name', '%' . $name . '%'); $stmt->execute();</code>
使用範例:bindParam()
或者,bindParam()方法可以如下所示使用:
<code class="php">$name = "%$name%"; $query = $dbh->prepare("SELECT * FROM `gc_users` WHERE `name` like :name"); $query->bindParam(':name', $name); $query->execute();</code>
透過採用這些技術,可以使用準備好的語句有效地執行模式比對查詢,同時保持安全性並防止SQL 注入漏洞。
以上是如何使用帶有通配符的 PDO 準備語句進行高效率 SQL 查詢?的詳細內容。更多資訊請關注PHP中文網其他相關文章!