ES模糊查询失效的坑以及解决方案
项目场景:
最近在做需求开发的时候,有个需求,需要根据关键字去ES中进行模糊搜索。于是首先想到了wildcard查询,根据关键字,利用*通配符,类似于mysql中的like一样进行模糊搜索。
问题描述
但是遇到了问题就是,根据单个汉字能正常模糊搜索,多个汉字就无法查询出数据。单个汉字正常查询:
多个汉字无法查出数据:
于是我就百度找解决方案,很多人说都说在查询关键字后面加 .keyword 就可以正常查询了,于是我接着尝试,
结果还是不能正常查询,而且原来单个汉字能查询的,现在也不行了
原因分析:
于是我怀疑是字段类型导致的,就有了下面这个我自己建的blog的测试索引。
咱们现在只关心索引中的name,newName1,newName2,newName3这4个字段,可以看到这4个字段的数据类型不同。现在创建一条数据,
根据name模糊查询
可以看到在keyword类型下,无论单个汉字,还是多个汉字都可以正常查询
- newName1的类型为text,最上面就是这种情况,单个汉字可以,多个汉字不行
- newName2的类型为wildcard,跟keyword情况一样
- newName3的类型为text,但是附加了keyword类型
单个汉字正常查询
多个汉字不能查询
加上keyword可以正常查询
总结:
- text类型,es会分词导致多个汉字不能正常正常查询
- keyword不分词可以正常查询
- wildcard和keyword类似
- text类型附加keyword类型,相当于支持两种类型,默认text,但是可以通过关键字加.keyword变成keyword类型
到此这篇关于ES模糊查询失效的坑以及解决方案的文章就介绍到这了,更多相关ES模糊查询失效内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
详解Springboot快速搭建跨域API接口的步骤(idea社区版2023.1.4+apache-maven-3.9.
这篇文章主要介绍了Springboot快速搭建跨域API接口(idea社区版2023.1.4+apache-maven-3.9.3-bin),本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下2023-07-07SpringBoot整合Mybatis实现多数据源配置与跨数据源事务实例
开发中经常有这样的需要: 读写分离。微服务环境下可以实现一个服务读取一个数据库,另一个服务写库。但是在实际应用中有时也需要在一个服务中读写不同的数据库。可以在一个SpringBoot单体项目中配置多个数据源解决读写库分离2022-11-11一个applicationContext 加载错误导致的阻塞问题及解决方法
这篇文章主要介绍了一个applicationContext 加载错误导致的阻塞问题及解决方法,需要的朋友可以参考下2018-11-11springboot整合mybatis实现多表查询的实战记录
SpringBoot对数据库操作有多种方式,下面这篇文章主要给大家介绍了关于springboot整合mybatis实现多表查询的相关资料,文中通过示例代码以及图文介绍的非常详细,需要的朋友可以参考下2021-08-08
最新评论