优化 InnoDB 中 LIKE '%string%' 的 MySQL 查询
问题描述
在 InnoDB 表查询中使用 LIKE '%string%' 子句时,观察到 'keywords' 列上的索引失效,导致全表扫描。
解决方案
InnoDB 索引针对从索引列开头开始的字符串比较进行了优化。但是,LIKE '%string%' 子句允许搜索词出现在列中的任何位置。此类查询不能使用基于开头的索引,因为搜索词未锚定在字符串的开头。
全文索引作为最佳解决方案
优化InnoDB 中涉及浮动搜索词的查询,应使用全文索引。全文索引是专门为处理此类查询而设计的,因为它们允许灵活的字符串匹配。
升级到 MySQL 5.6.4 或更高版本
InnoDB 对全文索引的支持是MySQL 5.6.4 中引入。如果您的MySQL版本低于5.6.4,建议升级以使用此功能。通过升级到 MySQL 5.6.4 或更高版本,您将能够使用全文索引来优化 InnoDB 中的 LIKE '%string%' 查询。
以上是## 如何让 MySQL LIKE \'%string%\' 在 InnoDB 中高效查询?的详细内容。更多信息请关注PHP中文网其他相关文章!