RDS MySQL 全文检索相关问题的处理

RDS MySQL 全文检索相关问题

1. RDS MySQL 对全文检索的支持

2. RDS MySQL 全文检索相关参数

3. RDS MySQL 全文检索中文支持

3.1 MyISAM 引擎表

3.2 InnoDB 引擎表

4. like ‘%xxx%‘ 和全文检索的比较

4.1 like ‘%xxx%‘

4.2 全文检索

5. ft_query_expansion_limit 参数作用


1. RDS MySQL 对全文检索的支持

RDS MySQL 5.5 仅 MyISAM 引擎表支持全文索引,RDS MySQL 5.6 版本 MyISAM 和 InnoDB 引擎都支持全文索引。

2. RDS MySQL 全文检索相关参数

可以在控制台  参数设置来设置下列参数。

# 参数名称 默认值 最小值 最大值 作用
1 ft_min_word_len 4 1 3600 MyISAM 引擎表全文索引包含的最小词长度
2 ft_query_expansion_limit 20 0 1000 MyISAM引擎表使用 with query expansion 进行全文搜索的最大匹配数
3 innodb_ft_min_token_size 3 0 16 InnoDB 引擎表全文索引包含的最小词长度
4 innodb_ft_max_token_size 84 10 84 InnoDB 引擎表全文索引包含的最大词长度
show global variables like ‘ft_%‘; --查看 MyISAM 引擎表全文检索相关参数

show global variables like ‘innodb_ft%‘; --查看 InnoDB 引擎表全文检索相关参数

3. RDS MySQL 全文检索中文支持

MyISAM 引擎表和 InnoDB 引擎表(需 RDS MySQL 5.6 版本)都支持中文全文检索。

3.1 MyISAM 引擎表

MyISAM 引擎表需要将 ft_min_word_len 设置为小于等于需要检索的最小分词长度,设置完毕后建议重新创建表上已有的全文索引;对于中文检索,建议将 ft_min_word_len 设置为 1。

CREATE TABLE `my_ft_test_02` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` text,
  PRIMARY KEY (`id`),
  FULLTEXT KEY `idx_ft_name` (`name`)
) ENGINE=MyISAM AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

--重建全文索引步骤:

alter table my_ft_test_02 drop key idx_ft_name; --删除已有的全文索引

alter table my_ft_test_02 add fulltext key idx_ft_name (name); --重新添加全文索引

3.2 InnoDB 引擎表

InnoDB 引擎表需要将 innodb_ft_min_token_size 设置为小于等于需要检索的最小分词长度,设置完毕后建议重新创建表上已有的全文索引;对于中文检索,建议将 ft_min_word_len 设置为 1。

CREATE TABLE `my_ft_test_01` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` text,
  PRIMARY KEY (`id`),
  FULLTEXT KEY `idx_ft_name` (`name`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

--重建全文索引的步骤:

alter table my_ft_test_01 drop key idx_ft_name; --删除已有的全文索引

alter table my_ft_test_01 add fulltext key idx_ft_name (name); --重新创建全文索引

4. like ‘%xxx%‘ 和全文检索的比较

4.1 like ‘%xxx%‘

对于数据量比较小,查询条件无法分词的情况下,可以考虑使用 like ‘%xxx%‘ 来进行查询。但是由于 like  ‘%xxx%‘ 这样的条件无法使用字段上的索引,因此通常执行时间较长,会耗费比较多的资源;建议结合查询其他条件来使用,这样可以尽量使用其他字段的索引来加速查询。

4.2 全文检索

全文检索本身是按 进行匹配,因此返回的结果会和 like ‘%xxx%‘ 的方式有所区别

5. ft_query_expansion_limit 参数作用

MySQL 全文检索支持扩展检索,具体请参考带查询扩展的全文检索

参数 ft_query_expansion_limit 的作用是指定MyISAM引擎表使用with query expansion进行全文搜索的最大匹配数,下面以一个例子来说明其作用。

参数 ft_query_expansion_limit 当前设置为 20:

当前表中相关的记录情况:

使用查询扩展的结果:

如果问题还未能解决,请联系售后技术支持

jpg改rar

时间: 2024-10-07 05:26:22

RDS MySQL 全文检索相关问题的处理的相关文章

RDS For MySQL 字符集相关说明

https://help.aliyun.com/knowledge_detail/41706.html?spm=5176.7841698.2.9.F5YjI5 字符序命名规则 字符集相关 MySQL 命令 控制台修改字符集参数 ( character_set_server ) 的方法 使用 sql 语句修改数据库字符集的方法 如何保证数据库字符集编码正确设置 1. 字符序命名规则 以字符序对应的字符集名称开头,以 _ci(大小写不敏感)._cs(大小写敏感)._bin(按编码值比较,大小写敏感)

RDS MySQL 表上 Metadata lock 的产生和处理

1. Metadata lock wait 出现的场景 2. Metadata lock wait 的含义 3. 导致 Metadata lock wait 等待的活动事务 4. 解决方案 5. 如何避免出现长时间 Metadata lock wait 导致表上相关查询阻塞,影响业务 1. Metadata lock wait 出现的场景 创建.删除索引 修改表结构 表维护操作(optimize table.repair table 等) 删除表 获取表上表级写锁 (lock table tab

MySQL全文检索

一.概述 MySQL全文检索是利用查询关键字和查询列内容之间的相关度进行检索,可以利用全文索引来提高匹配的速度. 二.语法 MATCH (col1,col2,...) AGAINST (expr [search_modifier]) search_modifier: { IN BOOLEAN MODE | WITH QUERY EXPANSION } 例如: SELECT * FROM tab_name WHERE MATCH ('列名1,列名2...列名n') AGAINST('词1 词2 词

使用阿里云ECS自建RDS MySQL从库

友情提示:安装MySQL软件步骤本文暂不介绍,安装完MySQL无需着急初始化数据库和启动服务.只需确保安装的MySQL版本不低于阿里云RDS MySQL版本,同时提前新建运行MySQL服务的mysql系统用户.出于安全,部分内容已打马赛克.采用何种模式做主从由RDS MySQL版本决定.本文主要使用RDS MySQL 5.6版作为样例说明,使用新的GTID模式做主从.5.5版配置主从更加简单,前15步操作一样,没有16.17步操作,18步使用binlog文件和位置的传统模式做主从,修改对应SQL

mysql 索引相关

引言: MYSQL由于其免费和开源的性质,在项目中用处广泛.大家都知道,一个MySQL数据库能够储存大量的数据,如果要在大量的数据中查找某一个数据,如果使用全表检索的话,即费时间又费力气,这时,就需要一种手段来减少这种消耗,这时候,索引就出现了!这里就简要介绍一下MYSQL的索引相关的内容. 索引是啥球东西: 索引的作用就像是相当于图书的目录,可以根据目录中的页码快速找到所需的内容.当表中有大量记录时,若要对表进行查询,第一种搜索方式是全表搜索,将所有记录一一取出,和查询条件进行一一对比,然后返

Configure Amazon RDS mysql to store Chinese Characters

Configure Amazon RDS mysql to store Chinese Characters https://dev.mysql.com/doc/refman/5.7/en/charset-applications.html http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-rds-database-instance.html#cfn-rds-dbinstance-charac

MySQL 的相关介绍

MySQL 的相关介绍 : 在介绍MySQL之前先弄清楚两个概念: 数据库:与DB相关的物理操作系统文件和其他形式文件的集合 实例:包括与MySQL相关的后台线程和共享内存区 在一般情况下一个实例仅仅对应于一个数据库的,像类似于高可用性集群的那种架构 就是一个数据库对应于多个实例 MySQL 的体系结构: 连接池组件 管理服务和工具组件 sql接口组件 查询分析组件 优化器组件 缓冲组件 插件式存储引擎 物理文件 下图很好的表现了这种体系结构: 常用的MySQL存储引擎 MYISAM特点:不支持

RDS MySQL 连接数满情况的处理

RDS MySQL 连接数满情况的处理 RDS MySQL 连接数满有2种情况 1. 空闲连接过多 原因: 应用使用长连接模式 - 对于长连接模式(比如Java应用),应用侧应该配置连接池.连接池的初始连接数设置过高,应用启动后建立多个到RDS实例空闲连接.如果出现连接数满(too many connections)不能连接的问题,请检查连接池是否启用了复用连接功能. 应用使用短连接模式 - 对于短连接模式(比如PHP应用),出现大量的空闲连接说明应用没有在查询执行完毕后显式的关闭连接.用户应该

mysql 全文检索的匹配问题

开发过程中碰到一个关于mysql 全文检索的问题,控制台打印的SQL语句拿到数据库里执行,结果不对.后来发现原来是少了双引号.下面是网上找到的资料,我是看到这个才意识到自己的问题. 这是之前在数据库执行的SQL语句,检索结果上万条. SELECT DISTINCT c.Rm_Code, c.Tsr_Code, c.TradeName, c.Location, c.Tel_Number, c.Url, c.Nss_category1, c.Nss_category2 FROM CompanyMst