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,不然是不会生效的。
相关推荐
n***i952 分钟前
云原生数据库使用体验,与传统数据库差异
数据库·云原生
百***99246 小时前
MySql的慢查询(慢日志)
android·mysql·adb
q***13346 小时前
在linux(Centos)中Mysql的端口修改保姆级教程
linux·mysql·centos
理想三旬7 小时前
关系数据库
数据库
千寻技术帮8 小时前
50022_基于微信小程序同城维修系统
java·mysql·微信小程序·小程序·同城维修
无心水8 小时前
【分布式利器:RocketMQ】2、RocketMQ消息重复?3种幂等方案,彻底解决重复消费(附代码实操)
网络·数据库·rocketmq·java面试·消息幂等·重复消费·分布式利器
q***98529 小时前
基于人脸识别和 MySQL 的考勤管理系统实现
数据库·mysql
l1t9 小时前
用SQL求解advent of code 2024年23题
数据库·sql·算法
办公解码器10 小时前
Excel工作表打开一次后自动销毁文件,回收站中都找不到
数据库·excel
爬山算法11 小时前
Redis(127)Redis的内部数据结构是什么?
数据结构·数据库·redis