InnoDB 表的类全文搜索优化
InnoDB 表提供了出色的性能和可靠性,但它们本身缺乏全文搜索功能。但是,可以通过利用 LIKE 语句和外部索引的组合来实现部分全文搜索功能。
解决方案
使用以下命令来模拟全文搜索类似,一种方法是利用辅助 MyISAM 表作为主 InnoDB 表的索引层。该辅助表称为“全文搜索表”,存储 InnoDB 表中所需列的索引副本。
步骤:
示例:
考虑一个“线程”表InnoDB 包含我们想要使其可搜索的“主题”列。我们创建一个具有类似架构的 MyISAM 全文搜索表“threads_ft”。为了促进同步,我们使用触发器或批量更新来反映从 InnoDB“threads”表到“threads_ft”的更改。
搜索存储过程“ft_search_threads”接受搜索参数并返回相关线程。它将搜索表与 InnoDB 表连接起来,以获取其他元数据,并根据“主题”列的 LIKE 匹配对结果进行排名。
优点:
注意事项:
以上是如何使用LIKE语句和外部索引实现InnoDB表的部分全文检索?的详细内容。更多信息请关注PHP中文网其他相关文章!