首页 > 数据库 > mysql教程 > 准备好的语句如何提高LIKE搜索的效率和安全性?

准备好的语句如何提高LIKE搜索的效率和安全性?

Susan Sarandon
发布: 2025-01-16 10:57:58
原创
285 人浏览过

How Can Prepared Statements Improve the Efficiency and Security of LIKE Searches?

使用准备好的语句优化 LIKE 搜索

使用 LIKE 运算符进行模式匹配的数据库查询需要仔细处理,以防止漏洞并确保性能。 使用不当可能会导致错误。

让我们检查一些有缺陷的方法:

<code class="language-sql">$sql = 'SELECT * FROM `users` WHERE username LIKE \'%{?}%\' ';</code>
登录后复制

此操作失败,因为 SQL 字符串中的变量数量与提供给 bind_param() 的参数不匹配。

<code class="language-sql">$sql = 'SELECT * FROM `users` WHERE username LIKE %{?}% ';</code>
登录后复制

由于查询字符串中通配符 (%{}) 的放置不正确,这会导致语法错误。

正确的方法使用准备好的语句,使用问号占位符并适当地绑定变量:

<code class="language-php">$likeVar = "%" . $yourParam . "%";
$stmt = $mysqli->prepare("SELECT * FROM REGISTRY where name LIKE ?");
$stmt->bind_param("s", $likeVar);
$stmt->execute();</code>
登录后复制

此代码:

  1. 通过将百分号连接到用户输入 ($yourParam) 来构造模式。
  2. 使用 ? 占位符准备查询。
  3. 使用 bind_param() 绑定模式字符串(“s”表示字符串)。
  4. 执行准备好的语句。

将准备好的语句与LIKE一起使用可以防止SQL注入并提高查询效率。

以上是准备好的语句如何提高LIKE搜索的效率和安全性?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板