ES模糊查询失效的坑,附解决方案

项目场景:

最近在做需求开发的时候,有个需求,需要根据关键字去ES中进行模糊搜索。于是首先想到了wildcard查询,根据关键字,利用*通配符,类似于mysql中的like一样进行模糊搜索。

问题描述

但是遇到了问题就是,根据单个汉字能正常模糊搜索,多个汉字就无法查询出数据。
单个汉字正常查询:
单个汉字正常查询
多个汉字无法查出数据:
多个汉字无法查出数据
于是我就百度找解决方案,很多人说都说在查询关键字后面加 .keyword 就可以正常查询了,于是我接着尝试,
在这里插入图片描述
结果还是不能正常查询,而且原来单个汉字能查询的,现在也不行了
在这里插入图片描述

原因分析:

于是我怀疑是字段类型导致的,就有了下面这个我自己建的blog的测试索引。
在这里插入图片描述
咱们现在只关心索引中的name,newName1,newName2,newName3这4个字段,可以看到这4个字段的数据类型不同。
现在创建一条数据,
在这里插入图片描述

  1. 根据name模糊查询
    在这里插入图片描述
    在这里插入图片描述
    可以看到在keyword类型下,无论单个汉字,还是多个汉字都可以正常查询
  2. newName1的类型为text,最上面就是这种情况,单个汉字可以,多个汉字不行
  3. newName2的类型为wildcard,跟keyword情况一样
    在这里插入图片描述
    在这里插入图片描述
  4. newName3的类型为text,但是附加了keyword类型
    单个汉字正常查询
    在这里插入图片描述
    多个汉字不能查询
    在这里插入图片描述
    加上keyword可以正常查询
    在这里插入图片描述

总结:

  1. text类型,es会分词导致多个汉字不能正常正常查询
  2. keyword不分词可以正常查询
  3. wildcard和keyword类似
  4. text类型附加keyword类型,相当于支持两种类型,默认text,但是可以通过关键字加.keyword变成keyword类型
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值