在需要在数据库中搜索包含以下内容的行的情况下特定列中的关键字“foo”和“bar”,您可以选择使用 MATCH AGAINST 或 LIKE。但哪一个是更好的选择?
MATCH AGAINST 在与 MyISAM 表一起使用时拥有显着的性能优势,因为它利用全文索引来实现更快的搜索。相比之下,LIKE 执行全表扫描,随着表中行数的增加,效率越来越低。
但是,LIKE 在关键字检测方面具有优势,因为它可以检测部分匹配,例如 'xxfoo' ,而 MATCH AGAINST 需要完整的单词匹配。如果此功能至关重要,您可能需要考虑 LIKE,即使以性能为代价。
在 MySQL 5.6 及更高版本的情况下,InnoDB 表还支持 MATCH AGAINST,提供了更全面的解决方案,可以同时解决这两个问题性能和关键字匹配能力。
因此,首选取决于您的具体要求和数据库环境。为了在 MySQL 5.6 及更高版本中的 MyISAM 表或 InnoDB 表上获得最佳性能,MATCH AGAINST 通常是更好的选择。但是,如果您需要部分关键字检测,LIKE 可能仍然是一个可行的选择,尽管对于较大的数据集可能会产生潜在的性能影响。
以上是MATCH AGAINST 或 LIKE:哪个最适合 MySQL 中的关键字搜索?的详细内容。更多信息请关注PHP中文网其他相关文章!