综述
MySQL 提供了全文搜索的功能,可以使用 MySQL 内置的 FULLTEXT 索引或第三方搜索引擎,例如 Elasticsearch 等。下面是使用 MySQL 内置的 FULLTEXT 索引实现全文搜索的步骤:
- 创建 FULLTEXT 索引
在需要进行全文搜索的表中,将需要搜索的列添加 FULLTEXT 索引。例如,如果我们要对表 my_table 中的 title 和 content 列进行全文搜索,可以使用以下 SQL 语句创建 FULLTEXT 索引:
ALTER TABLE my_table ADD FULLTEXT(title, content);
- 执行全文搜索
使用 MATCH AGAINST 子句执行全文搜索。例如,要搜索包含关键字 “apple” 的文本,可以使用以下 SQL 语句:
SELECT * FROM my_table WHERE MATCH(title, content) AGAINST('apple');
可以使用 IN BOOLEAN MODE 模式执行更高级的全文搜索。例如,要搜索同时包含关键字 “apple” 和 “fruit” 的文本,可以使用以下 SQL 语句:
SELECT * FROM my_table WHERE MATCH(title, content) AGAINST('+apple +fruit' IN BOOLEAN MODE);
- 优化全文搜索
可以使用以下方法优化全文搜索的性能:
调整 innodb_ft_min_token_size 参数,控制词条的最小长度;
调整 ft_max_word_len 和 ft_min_word_len 参数,控制词条的最大和最小长度;
使用 ft_stopword_file 参数指定停用词文件,去除常用词汇,减少噪音;
在 FULLTEXT 索引后使用普通索引,以便更快地查找;
避免在 WHERE 子句中使用函数或表达式,这会导致全表扫描;
尽可能减少匹配词条,以提高查询效率。
总的来说,MySQL 提供了内置的 FULLTEXT 索引来实现全文搜索,可以根据具体的情况进行调整和优化,以提高全文搜索的性能和效果。
优点
-
内置全文搜索功能:MySQL 自带全文搜索功能,可以通过创建 FULLTEXT 索引来快速进行全文搜索,不需要额外安装和配置搜索引擎软件。
说白了就是没那么多事,不用加入乱七八糟的东西,没啥侵入性,这也是最大的优点
-
简单易用:使用 MySQL 进行全文搜索不需要学习额外的查询语言或 API,只需要掌握 SQL 语言即可,易于上手和使用。
-
可扩展性好:MySQL 是一个成熟稳定的数据库系统,支持分布式和集群部署,可以根据需要进行水平和垂直扩展,满足不同规模和需求的应用场景。
-
数据安全性高:MySQL 提供了完善的用户认证和权限控制机制,可以保护敏感数据的安全性。
缺点
-
性能瓶颈:在大规模数据或高并发访问的情况下,MySQL 内置的 FULLTEXT 索引可能会出现性能瓶颈,需要进行优化或考虑使用第三方搜索引擎。
-
搜索能力有限:相比于一些专业的搜索引擎软件,MySQL 的全文搜索能力有一定限制,例如无法进行复杂的语义分析和推荐。
-
不支持高级查询:MySQL 的全文搜索不支持复杂的高级查询语法,例如通配符、正则表达式、近义词和近似搜索等,需要在应用程序中进行额外处理。
其实主要就是这个问题,即你没有办法做到模糊搜索或者是纠错搜索