MySQL 中文全文检索
短信预约 -IT技能 免费直播动态提醒
创建索引(MySQL 5.7.6后全文件索引可用WITH PARSER ngram,针对中文,日文,韩文)
ALTER TABLE 表 ADD FULLTEXT 索引名 (`字段`) WITH PARSER ngram;或者CREATE FULLTEXT INDEX 索引名 ON 表 (`字段`) WITH PARSER ngram;
查询方法
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
,不然是不会生效的。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341