es配置 查询

es配置

@Data
@Configuration
public class ESConfig {

    @Value("${es.config.hostname}")
    private String hostName;

    @Bean
    public RestHighLevelClient esRestHighLevelClient() {
        String[] hostNameArr = hostName.split(",");
        HttpHost[] httpHostArr = new HttpHost[hostNameArr.length];
        for (int i = 0; i < hostNameArr.length; i++) {
            String[] splitArr = hostNameArr[i].split(":");
            HttpHost httpHost = new HttpHost(splitArr[0], Integer.valueOf(splitArr[1]), "http");
            httpHostArr[i] = httpHost;
        }
        RestHighLevelClient client = new RestHighLevelClient(
                // 这里可以配置多个 es服务,我当前服务不是集群,所以目前只配置一个
                RestClient.builder(httpHostArr));

        return client;
    }
}

分组查询

 public ParsedStringTerms termsAggregate(RestHighLevelClient esRestHighLevelClient, Map<String, Object> mustMap,
                                                String rangeField, String startRange, String endRange, String key, int topN) {

        SearchRequest searchRequest = new SearchRequest();

        // 根据多个条件 生成 boolQueryBuilder
        BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();
        // 循环添加多个条件
        for (Map.Entry<String, Object> entry : mustMap.entrySet()) {
            boolQueryBuilder.must(QueryBuilders
                    .matchQuery(entry.getKey(), entry.getValue()));
        }
        if (StrUtil.isNotBlank(rangeField) && StrUtil.isNotBlank(startRange) && StrUtil.isNotBlank(endRange)) {
            if (startRange.length() == 10) {
                startRange = startRange + " 00:00:00";
            }
            if (endRange.length() == 10) {
                endRange = endRange + " 23:59:59";
            }
            boolQueryBuilder.must(QueryBuilders.rangeQuery(rangeField).gte(startRange).lte(endRange));
        } else if (StrUtil.isNotBlank(rangeField) && StrUtil.isNotBlank(startRange) && !StrUtil.isNotBlank(endRange)) {
            if (startRange.length() == 10) {
                startRange = startRange + " 00:00:00";
            }
            boolQueryBuilder.must(QueryBuilders.rangeQuery(rangeField).gte(startRange));
        } else if (StrUtil.isNotBlank(rangeField) && !StrUtil.isNotBlank(startRange) && StrUtil.isNotBlank(endRange)) {
            if (endRange.length() == 10) {
                endRange = endRange + " 23:59:59";
            }
            boolQueryBuilder.must(QueryBuilders.rangeQuery(rangeField).lte(endRange));
        }

        SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
        searchSourceBuilder.query(boolQueryBuilder).sort("date_time", SortOrder.DESC);
        searchSourceBuilder.query(boolQueryBuilder).aggregation(AggregationBuilders.terms("term").field(key).size(topN));
        log.info("ES查询DSL:==> {}", searchSourceBuilder.toString());
        searchRequest.source(searchSourceBuilder);
        searchRequest.indices(CommonConstants.ES_NAME);
        SearchResponse searchResponse = null;
        try {
            searchResponse = esRestHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);
        } catch (Exception e) {
            log.error("......terms aggregate failed:{}", e);
        }
        return searchResponse.getAggregations().get("term");
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值