繁体   English   中英

如何使用 spring-data-elasticsearch 中的聚合获取 elasticsearch json 响应?

[英]How to get the elasticsearch json response using aggregations in spring-data-elasticsearch?

我有以下内容:我注意到在运行代码结束时,如果我打印出 aggregations.asMap().get('subjects'); 我得到:org.elasticsearch.search.aggregations.bucket.terms.StringTerms@6cff59fa

打印出“聚合”给我:org.elasticsearch.search.aggregations.InternalAggregations@65cf321d

我真正想要的是整个字符串/json 响应,如果您在 elasticsearch 上卷曲以获取聚合,通常会返回该响应。 如何从聚合查询中获取原始响应? 另外,有没有一种方法可以迭代并打印出那些“包装”对象中的内容?

https://github.com/spring-projects/spring-data-elasticsearch/blob/ab7e870d5f82f6c0de236048bd7001e8e7d2a680/src/test/java/org/springframework/data/elasticsearch/core/aggregation/ElasticsearchTemplateAggregationTests.java

@Test
public void shouldReturnAggregatedResponseForGivenSearchQuery() {
    // given
    SearchQuery searchQuery = new NativeSearchQueryBuilder()
            .withQuery(matchAllQuery())
            .withSearchType(COUNT)
            .withIndices("articles").withTypes("article")
            .addAggregation(terms("subjects").field("subject"))
            .build();
    // when
    Aggregations aggregations = elasticsearchTemplate.query(searchQuery, new ResultsExtractor<Aggregations>() {
        @Override
        public Aggregations extract(SearchResponse response) {
            return response.getAggregations();
        }
    });
    // then
    System.out.println(aggregations); // gives me some cryptic InternalAggregations object, how do I get to the raw JSON normally returned by elasticsearch?
    System.out.println(aggregations.asMap().get("subjects")); // gives me some StringTerms object I have no idea how to iterate over to get results
}

您无法通过这种方式获得原始 JSON 响应,因为 Spring Data Elasticsearch 将为您解析它,这就是重点。

如果你需要解析这些桶,你可以很容易地这样做:

...
StringTerms subjects = aggregations.asMap().get("subjects");
for (Terms.Bucket bucket : subjects.getBuckets()) {
    String key = bucket.getKey();
    long docCount = bucket.getDocCount();
    // do something with the key and the doc count
}

如果你真的想看到返回的 JSON,你可以做的是使用序列化将解析的 Aggregations 对象重写成 JSON,但这实际上没有帮助:

InternalAggregations aggregations = ...;
XContentBuilder jsonBuilder = JsonXContent.contentBuilder();
aggregations.toXContent(jsonBuilder, ToXContent.EMPTY_PARAMS);
String rawJson = jsonBuilder.string();

将 EsRequest 的大小设置为零

获取 Esresponse.toString()

字符串转Json

从 Json 获取聚合字段。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM