MySQL全文索引的坑 20211202

本文记录了在MySQL中使用FULLTEXT索引进行全文搜索的实践过程。遇到的问题包括:FULLTEXT索引不支持中文分词,需配合ngram使用;查询效率低于LIKE'%xxx%',可能因词频过高或参数设置不当;以及遇到的FTS查询超过缓存限制的问题,可通过调整innodb_ft_result_cache_limit解决。全文索引对于前缀查询有效,但对于子串匹配效率较低。
摘要由CSDN通过智能技术生成

由于写 LIKE '%xxx%'需要全部遍历太慢了,所以试图来做全文索引。

看了MySQL的说明,可以有FULLTEXT索引,但用的过程出了一点问题,在此记录:

  1. FULLTEXT索引不是完全的子串匹配!!!只是模糊匹配!!!
  2. 中文分词问题:直接用FULLTEXT KEY是没有中文分词的!需要使用ngram,例如:create fulltext index b on try_table(file_path) with parser ngram
  3. 查询的时候,用SELECT * FROM try_table where match(file_path) against('123北京') limit 100;
  4. FULLTEXT索引用上之后,反而比直接LIKE '%xxx%'更慢,可能因为被查询的词的出现次数太多了,也可能因为设置参数不好(ngram_token_size默认为2)
  5. ERROR 188 (HY000): FTS query exceeds result cache limit:原因是缓存不足,可以调整innodb_ft_result_cache_limit(通过执行set GLOBAL innodb_ft_result_cache_limit=2000000000设置) https://support.oracle.com/knowledge/Oracle%20Database%20Products/2439029_1.html
  6. 关于字符串索引:如果只是LIKE 'xxx%'这样的前缀索引,直接用mysql的index还是很快的。但如果是子串匹配,会很慢。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值