csonezp

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

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检索使用方式了。

 

posted on 2022-05-30 18:48  csonezp  阅读(2090)  评论(0编辑  收藏  举报