MySQL 的 FIND_IN_SET 或等效函数可以使用索引吗?

Patricia Arquette
发布: 2024-11-05 21:22:02
原创
133 人浏览过

Can MySQL's FIND_IN_SET or an Equivalent Function Utilize Indices?

MySQL FIND_IN_SET 或等效的方法可以使用索引吗?

查询 SELECT * FROM Foo WHERE FIND_IN_SET(id, '2,3')不利用主键索引。将其 EXPLAIN 输出与确实利用索引的 SELECT * FROM Foo WHERE id IN (2,3) 的输出进行比较时,这一点很明显。

目标: 构造一个具有以下行为的存储过程与第二个查询一样,在不事先了解包含 ID 的逗号分隔字符串的情况下利用索引。

解决方案:

创建一个接受字符串作为的准备好的语句参数:

CREATE PROCEDURE my_sp(@id_string NCHAR(1000))
登录后复制

然后可以使用逗号分隔的字符串作为参数来执行准备好的语句:

EXEC my_sp '2,3'
登录后复制

此方法实现了以下所需条件:

  • type is range (not ALL)
  • key is not NULL

这些条件表明索引正在被使用。

安全注意事项:

准备好的语句可以降低 SQL 注入攻击的风险。然而,确保用户提供的数据经过净化以防止二级 SQL 注入攻击仍然至关重要。

以上是MySQL 的 FIND_IN_SET 或等效函数可以使用索引吗?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!