全文检索-MYSQL

综述

MySQL 提供了全文搜索的功能,可以使用 MySQL 内置的 FULLTEXT 索引或第三方搜索引擎,例如 Elasticsearch 等。下面是使用 MySQL 内置的 FULLTEXT 索引实现全文搜索的步骤:

  1. 创建 FULLTEXT 索引
    在需要进行全文搜索的表中,将需要搜索的列添加 FULLTEXT 索引。例如,如果我们要对表 my_table 中的 title 和 content 列进行全文搜索,可以使用以下 SQL 语句创建 FULLTEXT 索引:
ALTER TABLE my_table ADD FULLTEXT(title, content);
  1. 执行全文搜索
    使用 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);
  1. 优化全文搜索
    可以使用以下方法优化全文搜索的性能:
    调整 innodb_ft_min_token_size 参数,控制词条的最小长度;
    调整 ft_max_word_len 和 ft_min_word_len 参数,控制词条的最大和最小长度;
    使用 ft_stopword_file 参数指定停用词文件,去除常用词汇,减少噪音;
    在 FULLTEXT 索引后使用普通索引,以便更快地查找;
    避免在 WHERE 子句中使用函数或表达式,这会导致全表扫描;
    尽可能减少匹配词条,以提高查询效率。
    总的来说,MySQL 提供了内置的 FULLTEXT 索引来实现全文搜索,可以根据具体的情况进行调整和优化,以提高全文搜索的性能和效果。

优点

  1. 内置全文搜索功能:MySQL 自带全文搜索功能,可以通过创建 FULLTEXT 索引来快速进行全文搜索,不需要额外安装和配置搜索引擎软件。说白了就是没那么多事,不用加入乱七八糟的东西,没啥侵入性,这也是最大的优点

  2. 简单易用:使用 MySQL 进行全文搜索不需要学习额外的查询语言或 API,只需要掌握 SQL 语言即可,易于上手和使用。

  3. 可扩展性好:MySQL 是一个成熟稳定的数据库系统,支持分布式和集群部署,可以根据需要进行水平和垂直扩展,满足不同规模和需求的应用场景。

  4. 数据安全性高:MySQL 提供了完善的用户认证和权限控制机制,可以保护敏感数据的安全性。

缺点

  1. 性能瓶颈:在大规模数据或高并发访问的情况下,MySQL 内置的 FULLTEXT 索引可能会出现性能瓶颈,需要进行优化或考虑使用第三方搜索引擎。

  2. 搜索能力有限:相比于一些专业的搜索引擎软件,MySQL 的全文搜索能力有一定限制,例如无法进行复杂的语义分析和推荐。

  3. 不支持高级查询:MySQL 的全文搜索不支持复杂的高级查询语法,例如通配符、正则表达式、近义词和近似搜索等,需要在应用程序中进行额外处理。其实主要就是这个问题,即你没有办法做到模糊搜索或者是纠错搜索

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值