mysql 全文索引中的Stopwords

Full-Text Stopwords 是指在全文搜索时被索引系统默认忽略的一组单词。这些通常是最常见的单词,比如 "the"、"is"、"at" 等英语中的助词、介词、连接词等。它们通常不含有具体的搜索意义,因此在创建全文索引的时候会被排除在外,以便减少索引大小并提高搜索效率。

在 MySQL 中使用全文索引和搜索时,Stopwords 的作用如下:

  1. 索引构建 - 当创建全文索引时,Stopwords 不会被包括在内。这意味着,如果你的搜索关键字包含了这些词,它们不会出现在索引结果中。

  2. 搜索查询 - 当执行全文搜索时,如果搜索字符串包含 Stopwords,那么这些词将不会被用于匹配。

你可以通过查看 MySQL 的官方文档来获取默认的 Stopword 列表,并根据需要修改它。例如,在 MyISAM 引擎中,停用词列表存储在 storage/myisam/ft_static.c 文件中,而 InnoDB 引擎的停用词列表是由服务器变量 innodb_ft_default_stopword 指定的表。

若要改变默认的停用词集合,你可以进行以下操作:

  1. 自定义停用词表 - 通过设置系统变量(例如 ft_stopword_file)来指定自己的停用词文件路径,或者对于 InnoDB 表,通过给 innodb_ft_server_stopword_table 设置一个指向你自己停用词表的值。

  2. 重新生成索引 - 更改停用词表后,相关的全文索引需要重建,以确保新的停用词列表生效。

  3. 使用IN BOOLEAN MODE搜索 - 如果你想在搜索时忽略停用词列表,可以在全文搜索中使用 IN BOOLEAN MODE 选项,这样即使是停用词也会被用于搜索匹配。

举例来说,如果你对一个包含文章文本的列使用全文索引搜索,但希望 "the" 和 "is" 这样的常见单词能够在搜索中匹配,你可能需要自定义停用词表或使用 IN BOOLEAN MODE 进行搜索。

请注意,调整停用词列表可能影响搜索结果的相关性和性能,因此应谨慎进行。

相关推荐
计算机学姐5 分钟前
基于SpringBoot+Vue的家政服务预约系统【个性化推荐+数据可视化】
java·vue.js·spring boot·后端·mysql·信息可视化·java-ee
2301_793804697 分钟前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
夜空下的星10 分钟前
使用redisson操作redis详解
数据库·redis·缓存
weixin_4563216410 分钟前
生产环境Redis部署选型最佳实践
数据库·redis·缓存
gechunlian8811 分钟前
数据库(MySQL):使用命令从零开始在Navicat创建一个数据库及其数据表(一).创建基础表
数据库·mysql·oracle
堕27415 分钟前
MySQL数据库《基础篇--数据库JDBC编程》
数据库·mysql
FL4m3Y4n18 分钟前
Redis相关命令与原理
数据库·redis·缓存
小张贼嚣张21 分钟前
SQL 正则表达式详解:语法、函数与实战案例(MySQL/Oracle通用)
mysql·oracle·正则表达式
木易 士心23 分钟前
自然语言转数据库操作语句原理架构图分析和实现
数据库·后端
TDengine (老段)23 分钟前
TDengine IDMP 1-产品简介
大数据·数据库·物联网·时序数据库·tdengine·涛思数据