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类型
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhfhiheb
系列文章
更多
同类精品
更多
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01 -
怎样阻止微信小程序自动打开
PHP中文网 06-13