ElasticSearch:组合查询或复合查询

Bool查询

允许在单独的查询中组合任意数量的查询,指定的查询语句表名哪些部分是必须匹配(must)、应该匹配(should)或不能匹配(must_not)

Bool过滤器

和查询功能一致,但是同等情况下,推荐使用过滤器

Range查询和过滤

用于查询介于一定范围之内的值,适用于数字,日期,字符串。

参数
含义
gt搜索大于某值的字段,不包括该值本身
gte搜索大于某值的字段,包括该值本身
lt搜索小于某值的字段,不包括该值本身
lte搜索小于某值的字段,包括该值本身

使用range查询时,请仔细考虑一下过滤器是否为更好的选择。由于在查询范围之中的文档是二元的匹配(“是的,文档在范围之中”或者“不是,文档不在范围之中”),

range

查询不必是查询。为了获得更好的性能,它应该是过滤器。如果不确定使用查询还是过滤器,请使用过滤器。在99%的用例中,使用range过滤器是正确的选择。

Prefix查询与过滤

和term查询类似,prefix 查询和过滤器允许你根据给定的前缀来搜索词条,这里前缀在搜索之前是没有经过分析的。例如,为了在索引中搜索以“liber” 开头的全部活动。

wildcard查询

字面意思,通配符查询,可使用 *,?来匹配任意字符。

exists过滤器

正如其名,exists 过滤器允许你过滤文档,只查找那些在特定字段有值的文档,无论其值是多少。exists 过滤器看上去是这样的005OiRqWgy1g6gjsa23spj30u70c3n05

missing 过滤器

missing过滤器让你可以搜索字段里没有值,或者是映射时指定的默认值的文档(也叫作null值,即映射里的nul1 value)。 为了搜索缺失reviews字段的文档,可以使用下面这样的过滤器:clipboardclipboawwrd常用案例中使用哪些类型的查询

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ElasticSearch是一款基于Lucene的分布式搜索引擎,支持各种类型的查询。其中组合查询是指将多个查询条件组合起来进行查询,可以使用ElasticSearch的bool查询实现。 bool查询是一种复合查询,可以将多个查询条件组合起来,支持must、must_not、should、filter四种查询方式。 - must:表示必须匹配的查询条件,相当于“AND”的关系。 - must_not:表示必须不匹配的查询条件,相当于“NOT”的关系。 - should:表示可选匹配的查询条件,相当于“OR”的关系。 - filter:表示不评分的过滤条件,相当于must的变种,但它不会影响评分。 下面是一个使用bool查询实现组合查询的例子: ``` { "query": { "bool": { "must": [ { "match": { "title": "Elasticsearch" }}, { "match": { "content": "search" }} ], "must_not": [ { "match": { "content": "java" }} ], "should": [ { "match": { "author": "John" }}, { "match": { "tags": "elk" }} ], "filter": [ { "range": { "date": { "gte": "2022-01-01" }}} ] } } } ``` 上述查询语句中,我们使用bool查询将多个查询条件组合起来: - must条件表示title必须包含Elasticsearch,content必须包含search,相当于“Elasticsearch AND search”的关系。 - must_not条件表示content必须不包含java,相当于“NOT java”的关系。 - should条件表示author必须包含John,或tags必须包含elk,相当于“John OR elk”的关系。 - filter条件表示date必须大于等于2022-01-01,但不影响评分。 通过使用bool查询,我们可以实现各种复杂的组合查询

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值