Java中使用es条件构造器BoolQueryBuilder

前言

由于es在java中查询没法像mybatis那样方便,而且es的构造器使用也比较繁琐,理解不是很方便,所以写一篇文章来记录es构造器BoolQueryBuilder查询时各种条件的构造的正确姿势。

教程

1.构造准备
//1.构建SearchRequest请求对象,指定索引库
SearchRequest searchRequest = new SearchRequest("data_info");
//2.构建SearchSourceBuilder查询对象
SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
//2.1 这个条件用于返回所有命中条件的数据数量, 不设置则返回大概数值
sourceBuilder.trackTotalHits(true);
//3.检索条件构造
BoolQueryBuilder bqb = QueryBuilders.boolQuery();
2.条件构造
  • must可用filter代替,查询效率会更高,因为must会对结果进行_score评估
//3.1 完全匹配
bqb.must(QueryBuilders.matchQuery("code", 666L);
         
//3.2 模糊匹配
bqb.must(QueryBuilders.matchPhraseQuery("name", "张");
         
//3.3 in的效果 传单个参数就是完全匹配
bqb.must(QueryBuilders.termsQuery("code", new Long[]{1L, 2L, 3L});
bqb.must(QueryBuilders.termsQuery("code", 1L, 2L, 3L);
         
//3.4 or条件
BoolQueryBuilder shouldQuery = QueryBuilders.boolQuery();
shouldQuery.should(QueryBuilders.matchQuery("code", 1L);
shouldQuery.should(QueryBuilders.matchQuery("code", 2L);
shouldQuery.minimumShouldMatch(1); //至少满足一个
bqb.must(shouldQuery);
                   
//3.5 非null
bqb.must(QueryBuilders.existsQuery("iden"));
//是null             
bqb.mustNot(QueryBuilders.existsQuery("iden"));

//3.6 大于等于gte (gt-大于 lt-小于 lte-小于等于)
bqb.must(QueryBuilders.rangeQuery("time").gte(new Date());
         
//3.7 中文完全匹配
bqb.must(queryBuilder.matchPhraseQuery("key", value));

//3.8 匹配多个字段
bqb.must(queryBuilder.multiMatchQuery(value, key1, key2, key3));
3.构造完成 准备查询
//4.将QuseryBuilder对象设置到SearchSourceBuilder对象中
sourceBuilder.query(bqb);
//5.排序
sourceBuilder.sort("updateTime", SortOrder.DESC);
//6.分页
sourceBuilder.from((dto.getPageNum() - 1) * dto.getPageSize());
sourceBuilder.size(dto.getPageSize());

//7.将SearchSourceBuilder设置到SearchRequest中
searchRequest.source(sourceBuilder);

//8.调用方法查询数据
SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT);
         
//9.解析返回结果
SearchHit[] hits = searchResponse.getHits().getHits();
for (int i = 0; i < hits.length; i++) {
    System.out.println("返回的结果: " + hits[i].getSourceAsString());
}

log.info("返回总数为:" + searchResponse.getHits().getTotalHits());
int total = (int)searchResponse.getHits().getTotalHits().value;

原文地址: Java中使用es条件构造器BoolQueryBuilder

  • 10
    点赞
  • 71
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
JavaElasticsearch(简称ES)的构造器是指创建一个ES客户端连接的方式。ES是一个开源的、分布式的搜索和分析引擎,用于存储、检索和分析海量数据。 在Java使用ES,需要使用Elasticsearch Java High-Level REST Client来建立连接和与ES进行交互。要创建一个ES客户端对象,可以使用TransportClient或RestHighLevelClient。 TransportClient是ES旧版本的客户端对象,用于低层次的与ES节点进行通信。它需要指定ES集群的节点信息,如节点的IP地址和端口号等。例如,创建一个TransportClient对象的代码如下: ``` TransportClient client = new PreBuiltTransportClient(Settings.EMPTY) .addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName("localhost"), 9300)); ``` 而RestHighLevelClient是ES 5.0及以上版本的客户端对象,基于RESTful API进行交互,使用HTTP协议与ES进行通信。它不需要指定集群的节点信息,只需要指定ES服务的URL即可。例如,创建一个RestHighLevelClient对象的代码如下: ``` RestHighLevelClient client = new RestHighLevelClient( RestClient.builder( new HttpHost("localhost", 9200, "http"))); ``` 无论选择哪种方式,创建完成后,就可以使用client对象对ES进行操作,比如进行索引、搜索、添加文档等。在使用ES之后,需要调用client的close方法来关闭与ES的连接,释放资源。 总的来说,Java使用ES构造器就是创建一个与ES建立连接的客户端对象,通过这个客户端对象来进行数据的存储、检索和分析。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值