LIKE
搜索使用 LIKE
运算符进行模式匹配的数据库查询需要仔细处理,以防止漏洞并确保性能。 使用不当可能会导致错误。
让我们检查一些有缺陷的方法:
$sql = 'SELECT * FROM `users` WHERE username LIKE \'%{?}%\' ';
此操作失败,因为 SQL 字符串中的变量数量与提供给 bind_param()
的参数不匹配。
$sql = 'SELECT * FROM `users` WHERE username LIKE %{?}% ';
由于查询字符串中通配符 (%{}) 的放置不正确,这会导致语法错误。
正确的方法使用准备好的语句,使用问号占位符并适当地绑定变量:
$likeVar = "%" . $yourParam . "%"; $stmt = $mysqli->prepare("SELECT * FROM REGISTRY where name LIKE ?"); $stmt->bind_param("s", $likeVar); $stmt->execute();
此代码:
$yourParam
) 来构造模式。?
占位符准备查询。bind_param()
绑定模式字符串(“s”表示字符串)。将准备好的语句与LIKE
一起使用可以防止SQL注入并提高查询效率。
以上是准备好的语句如何提高LIKE搜索的效率和安全性?的详细内容。更多信息请关注PHP中文网其他相关文章!