elasticsearch查询QueryBuilders详解(es7.80)

elasticsearch查询QueryBuilders详解(es7.80)

目录

1 QueryBuilders.matchQuery(“supplierName”,param)

2 QueryBuilders.matchPhraseQuery(“supplierName”,param)

3 QueryBuilders.matchPhrasePrefixQuery(“supplierName”,param)

4 QueryBuilders.termQuery(“supplierName”,param)

5 QueryBuilders.wildcardQuery(“supplierName”,”*”+param+”*”) 

                                                总结


首先存入一条数据 i like eating and kuing 默认分词器应该将内容分为 “i” “like” “eating” “and” “kuing”
注意如果使用supplierName.keyword做查询(数据源采用es库中不分词数据)见https://blog.csdn.net/tyw15/article/details/

1 QueryBuilders.matchQuery(“supplierName”,param)

param = “i” 可查出i
param = “i li” 可查出
param = “i like” 可查出
param = “i like eat” 可查出
param = “and” 可查出
param = “kuing” 可查出

param = “ku”  查不出
param = “li”  查不出
param = “eat”  查不出

param = “i like eating and kuing” 查出

Grok 教程elasticsearch查询QueryBuilders详解(es7.80)

分词后精确查询,分词之间or关系,有一个分词匹配即匹配

如果使用  “match”: {“message.keyword“: “xxx”},即不分词只有 i like eating and kuing可以查出

elasticsearch查询QueryBuilders详解(es7.80)

2 QueryBuilders.matchPhraseQuery(“supplierName”,param)

param = “i” 可查出i
param = “i li” 查不出
param = “i like” 可查出
param = “i like eat” 查不出
param = “and” 可查出
param = “kuing” 可查出

param = “ku”  查不出
param = “li”  查不出
param = “eat”  查不出

param = “i like eating and kuing” 查出

有序连贯分词模糊查询(任意分词任意数量按照原有顺序连续排列组合可以查出,其他不可查出)

如果使用  “match_phrase”: {“message.keyword“: “xxx”},即不分词只有 i like eating and kuing可以查出

3 QueryBuilders.matchPhrasePrefixQuery(“supplierName”,param)

与match_phrase唯一区别  param = “i like eating and kui” 查出

elasticsearch查询QueryBuilders详解(es7.80)

最后一个词条之前的词匹配规则与match_phrase相同++最后一个此条为前缀进行模糊匹配

match_phrase_prefix不能使用supplierName.keyword模式

4 QueryBuilders.termQuery(“supplierName”,param)

 

而term query,输入的查询内容是什么,就会按照什么去查询,并不会解析查询内容,对它分词。

param = “i” 可查出i
param = “i li” 查不出
param = “i like” 查不出
param = “i like eat” 查不出
param = “and” 可查出
param = “kuing” 可查出

param = “ku”  查不出
param = “li”  查不出
param = “eat”  查不出
查询条件不分词精确匹配分词数据,命中一个分词即匹配

param = “i like eating and kuing” 查不出

如果使用  “term”: {“message.keyword“: “xxx”},即不分词只有 i like eating and kuing可以查出

5 QueryBuilders.(“supplierName”,param) 

elasticsearch查询QueryBuilders详解(es7.80)

不分词查询,加*(相当于sql中的%)表示模糊查询,加keyword表示查不分词数据 

{“wildcard”:{“message.keyword”:”*atin*”} 等同sql于like查询

不能使用supplierName.keyword模式

 

fieldName.keyword决定是否采用es分词数据源,不带keyword即查询text格式数据(分词),带即查询keyword格式数据(不分词)

见https://blog.csdn.net/tyw15/article/details/

match,match_phrase,match_phrase_prefix,term,决定查询条件分词形式以及分词后的查询条件关联关系

1、2、4使用.keyword查询相当于不分词精确匹配,5是模糊查询,其他都是变种分词组合模糊查询

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/245571.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月15日 下午7:42
下一篇 2026年3月15日 下午7:42


相关推荐

关注全栈程序员社区公众号