MySQL 中文全文检索

创建索引(MySQL 5.7.6后全文件索引可用WITH PARSER ngram,针对中文,日文,韩文)

sql 复制代码
ALTER TABLE 表 ADD FULLTEXT 索引名 (`字段`) WITH PARSER ngram;

或者

CREATE FULLTEXT INDEX 索引名 ON 表 (`字段`) WITH PARSER ngram;

查询方法

sql 复制代码
select * from 表 where match(字段名) against('关键词');

注意

  • 只能在类型为CHAR、VARCHAR或者TEXT的字段上创建全文索引。
  • 全文索引只支持InnoDB和MyISAM引擎。
  • MATCH()函数使用的字段名,必须要与创建全文索引时指定的字段名一致。
    多个字段索引,如MATCH (title,body) 创建索引字段名也要是(title,body)。如果要对title或者body字段分别进行查询,就需要在title和body字段上分别创建新的全文索引,然后使用and查询。
  • MATCH()函数使用的字段名只能是同一个表的字段,因为全文索引不能够跨多个表进行检索。
  • 如果要导入大数据集,使用先导入数据再在表上创建全文索引的方式要比先在表上创建全文索引再导入数据的方式快很多,所以全文索引是很影响TPS的。
  • 添加索引的时候注意记得加上 WITH PARSER ngram,不然是不会生效的。
相关推荐
山岚的运维笔记6 分钟前
SQL Server笔记 -- 第34章:cross apply
服务器·前端·数据库·笔记·sql·microsoft·sqlserver
落花流水 丶6 分钟前
MongoDB 完全指南
数据库·mongodb
文档搬运工9 分钟前
OS的load average很高
数据库
爬山算法12 分钟前
MongoDB(3)什么是文档(Document)?
数据库·mongodb
爬山算法14 分钟前
MongoDB(9)什么是MongoDB的副本集(Replica Set)?
数据库·mongodb
thginWalker33 分钟前
实战篇 & 结束篇
数据库
William_cl1 小时前
【EFCore 从入门到避坑】模型映射全解析:数据注解 VS FluentAPI(附实战代码 + 踩坑指南)
数据库·oracle
ghie90901 小时前
基于MATLAB的指纹定位算法仿真实现
数据库·算法·matlab
知识分享小能手1 小时前
SQL Server 2019入门学习教程,从入门到精通,Transact-SQL数据的更新 —语法详解与实战案例(SQL Server 2019)(10)
数据库·学习·sqlserver
Lw老王要学习1 小时前
无互联网的正式 CentOS 7.6环境中安装 mysql-8.0.36-1
linux·服务器·mysql·centos