ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Java ES 实现or查询

2022-05-30 19:02:43  阅读:159  来源: 互联网

标签:检索 boolQueryBuilder Java BoolQueryBuilder 查询 es test QueryBuilders ES


es mapping里有三个字段:

A:Integer

B:Integer

C:TEXT

现在想实现一个查询,来检索  (  (A =1 and B=2)  or (c like "test*")  )的数据。

分析:

 

这个检索条件 被 or 分割成两部分。

第一部分是一个 boo表达式,此表达式的自然语言含义是必须满足 A = 1而且B =2。

这部分用es的api写作:

        BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
        boolQueryBuilder.must(QueryBuilders.termQuery("A",1));
        boolQueryBuilder.must(QueryBuilders.termQuery("B", 2));

 

第二部分是一个前缀匹配,代码:

WildcardQueryBuilder wildcardQuery = QueryBuilders.wildcardQuery("processDefinitionKey", "test*");

 

这样就把一个层叠的检索条件拆分成了两个QueryBuilder,对于这两个QueryBuilder来说,他们之间任一满足即可,这时候就可以再构建一个BoolQueryBuilder将这两个条件组合起来

        BoolQueryBuilder queryBuilder = QueryBuilders.boolQuery();
        boolQueryBuilder.should(boolQueryBuilder);
        boolQueryBuilder.should(wildcardQuery);

 

这里构建出来的queryBuilder就是 (  (A =1 and B=2)  or (c like "test*")  ) 的es检索使用方式了。

 

标签:检索,boolQueryBuilder,Java,BoolQueryBuilder,查询,es,test,QueryBuilders,ES
来源: https://www.cnblogs.com/csonezp/p/16327842.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有