Elasticsearch Java API 的使用(6)—时间聚合

Java时间聚合

AggregationBuilder 构建聚合查询
AggregationBuilders 类可以调用很多聚合的方法,dateRange 可以对时间范围进行聚合。
示例如下:

public class EsAggregation{
    public void searchAggregation(TransportClient client){
        AggregationBuilder aggregation = AggregationBuilders
            .dateRange("agg")
            .field("inputtime")
            .format("yyyy-MM-dd HH:mm:ss")
            // from 1950 to 1960 (excluded)
            .addRange("2016-7-21 00:00:01", "2016-7-21 00:00:02");
        SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();
        sourceBuilder.aggregation(aggregation);

        System.out.println(sourceBuilder.toString());

        SearchResponse response =  client
                    .prepareSearch("pointdata")
                    .setTypes("pointdata")
                    .setQuery(QueryBuilders.queryStringQuery
                        ("W3.UNIT1.10LBG01CP301"))
                    .setSource(sourceBuilder)
                    .execute()
                    .actionGet();

        SearchHits hits = response.getHits();
        for(int i = 0; i < hits.getHits().length; i++) {
            System.out.println(i+":"+hits.getHits()[i].getSourceAsString());
        }

        // sr is here your SearchResponse object
        Range agg = response.getAggregations().get("agg");

        // For each entry
        for (Range.Bucket entry : agg.getBuckets()) {
             // Date range as key
             String key = entry.getKeyAsString(); 
             // Date bucket from as a Date  引用import org.joda.time.DateTime;            
             DateTime fromAsDate = (DateTime) entry.getFrom(); 
             // Date bucket to as a Date  
             DateTime toAsDate = (DateTime) entry.getTo(); 
             // Doc count      
             long docCount = entry.getDocCount();                

             System.out.println("key [{"+key+"}], from [{"+fromAsDate+"}], "+
                 "to [{"+toAsDate+"}], doc_count [{"+docCount+"}]");
            }
    }
}
好的,下面是一个使用Elasticsearch Java API进行分类统计聚合的例子: 假设我们有一个名为“products”的索引,其中包含产品名称和价格字段。我们想要按价格范围对产品进行分类统计,以便了解哪些价格区间的产品最受欢迎。 首先,我们需要创建一个聚合对象: ``` AggregationBuilder aggregation = AggregationBuilders .range("price_ranges") .field("price") .addUnboundedTo(50) .addRange(50, 100) .addRange(100, 200) .addRange(200, 500) .addUnboundedFrom(500); ``` 这个聚合对象将按价格字段对文档进行分类统计,并将它们分成五个范围:小于等于50、50到100、100到200、200到500和大于等于500。现在,我们需要将这个聚合对象添加到我们的搜索请求中: ``` SearchRequest searchRequest = new SearchRequest("products"); SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); searchSourceBuilder.aggregation(aggregation); searchRequest.source(searchSourceBuilder); ``` 这将创建一个`SearchRequest`对象,将聚合对象添加到`SearchSourceBuilder`中,并将其设置为`SearchRequest`的搜索源。现在,我们可以执行搜索请求并从结果中提取聚合信息: ``` SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); Range rangeAgg = searchResponse.getAggregations().get("price_ranges"); for (Range.Bucket bucket : rangeAgg.getBuckets()) { String key = bucket.getKeyAsString(); long docCount = bucket.getDocCount(); System.out.println("Range: " + key + ", Count: " + docCount); } ``` 这会执行搜索请求,并从响应中提取名为“price_ranges”的聚合对象。我们可以遍历每个范围桶,并提取范围键和文档计数。最后,我们可以将这些信息输出到控制台或将它们用于其他目的。 希望这个例子能够帮助你理解如何使用Elasticsearch Java API进行分类统计聚合
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值