elasticsearch的高级查询

#子条件查询:      特定字段查询 所指特定值(子条件查询又分为Query context 和 Filter context)

#符合条件查询:   以一定的逻辑组合子条件查询

 

Query context :

     在查询过程中,除了判断文档是否满足查询条件外,ES还会计算一个_score来标识匹配的程度,旨在判断目标文档和查询条件匹配的有多好

Query context常用查询:

 #全文本查询 :针对文本类型数据

#字段级别查询:针对结构化数据,如数字、日期等。

先介绍文本查询的模糊匹配

这是数据库中6条数据

对title字段查询(title定为为text类型,会自动分词)

发现返回结构中有菜谱或入门的数据都返回了

如果只想准确匹配“菜谱入门”则用match_phrase

多个字段匹配查询

对author和title两个字段查询“入门”,可以看到含有“入门”的author和title都查出来了(ps:  创建索引时author是keyword只能精确查找,不会分词)

query_string查询

查询 既有"入门"又有"哈哈"的数据

匹配“入门”AND "哈哈" 或者匹配“菜谱”

指定title和author字段,查询"张三"或“杂志”

返回结果:

文本查询到此结束,下面是字段的查询

指定查询word_count是2000的数据(查询结果就不展示了)

还可以按照范围查询

查询书籍字段在2000到5000的数据有哪些

(其中 gt是大于,gte大于等于,lt小于,lte小于等于)

同理查询日期

 

**************************************************************************************************************

 

子条件查询中的Filter context :

在查询过程中,只判断该文档是否满足条件,只有Yes或No ,用来数据过滤。(而query查询还会涉及匹配程度)

 

处理结果可以看到只有word_count为2000的信息查询出来

有个地方注意,应为title是text类型,分词了,term匹配"菜谱入门",查询没结果(把term换成match会查询出来)。

*****************************************************************************************************

 

综合query和filter的符合条件查询

复合查询有: 固定分数查询、布尔查询等等。。

先看一下普通的全文匹配

返回结果将title含有“入门”的信息都返回来了,且score分数都不一样

我们可以固定分数来查询

返回结果,_score全为2

***********************************************************************************************************

布尔查询

关键词should 匹配中match条件的一种即返回数据,是或的关系

结果中有王五、入门的信息都查到了,说明是或的关系

*********************************************************

布尔查询还有一个 must关键词,即两条必须同时满足,是与的关系

返回数据如下

must还可以和filter进行组合

*******************************************************

关键词must_not , 顾名思义,是一定不能满足的条件。

返回的结果中没有author为“王五”的信息,这里就不展示搜索结果了

most_not也可以用数组格式来满足多个匹配条件(term应用在不可分割字段上,match对text类型字段模糊查询)

 

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Data ElasticSearch高级查询是指在使用Spring Data ElasticSearch框架进行查询时,使用一系列高级查询功能来满足特定需求的操作。这些高级查询功能包括基本查询、自定义查询、分页查询和排序等。 在Spring Data ElasticSearch中,为了执行高级查询,我们可以使用ElasticsearchRepository接口提供的search方法。该方法需要一个QueryBuilder参数来构建查询条件。QueryBuilder可以使用QueryBuilders对象提供的方法来创建各种类型的查询,如词条查询、匹配查询等。 例如,如果我们想要执行一个词条查询,可以使用QueryBuilders的matchQuery方法来创建一个MatchQueryBuilder对象,并指定查询的字段和关键词。然后,将该查询对象作为参数传递给search方法,即可执行查询并获取结果。 除了基本查询之外,Spring Data ElasticSearch还提供了其他高级查询功能,如自定义查询、分页查询和排序。自定义查询可以根据具体需求使用不同的查询条件和操作符来构建复杂的查询语句。分页查询可以通过设置分页参数来获取指定范围内的查询结果。排序可以根据指定字段对查询结果进行排序。 总之,Data ElasticSearch高级查询是指使用Spring Data ElasticSearch框架提供的一系列高级查询功能来满足特定需求的操作,包括基本查询、自定义查询、分页查询和排序等。通过使用QueryBuilders对象创建QueryBuilder参数,我们可以构建出各种类型的查询条件,并通过search方法执行查询获取结果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [【Spring Data ElasticSearch高级查询,聚合](https://blog.csdn.net/qq_41879343/article/details/107452444)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhiaoo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值