(六)ElasticSearch7.X之聚合查询java代码(指定队伍指定字段的cardinality(去重之后总数))

POST /nba/_search
{
"query": {
"term": {
"teamNameEn.keyword": {
"value": "Rockets"
}
}
},
"aggs": {
"counAget": {
"cardinality": {
"field": "playYear"
}
}
},
"size": 0
}
 @Test
    public void test05() throws IOException {
        SearchRequest searchRequest = new SearchRequest("nba");
        SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
        //限定了查询的队伍名称
        searchSourceBuilder.query(QueryBuilders.termQuery("teamName.keyword","火箭")).size(100);
        CardinalityAggregationBuilder cardinalityAggregationBuilder = AggregationBuilders.cardinality("playYear").field("playYear");
        searchSourceBuilder.aggregation(cardinalityAggregationBuilder);
        searchRequest.source(searchSourceBuilder);
        SearchResponse search = client.search(searchRequest, RequestOptions.DEFAULT);
        Cardinality valueCount = search.getAggregations().get("playYear");
        long value = valueCount.getValue();
        System.out.println(value);
    }
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HyperLogLogPlusPlusAggregationBuilder 是一种基数聚合查询方法,它可以用于计算指定字段的基数(去后的数量)。 以下是一个使用 HyperLogLogPlusPlusAggregationBuilder 对统计结果进行去的示例代码: ```java import org.elasticsearch.search.aggregations.AggregationBuilders; import org.elasticsearch.search.aggregations.metrics.cardinality.HyperLogLogPlusPlusAggregationBuilder; public class AggregationExample { public static void main(String[] args) { HyperLogLogPlusPlusAggregationBuilder aggregationBuilder = AggregationBuilders .hyperLogLogPlusPlus("unique_users") .field("user_id"); //执行查询并获取去后的结果 long uniqueUsersCount = performQueryAndGetUniqueCount(aggregationBuilder); System.out.println("Unique users count: " + uniqueUsersCount); } private static long performQueryAndGetUniqueCount(HyperLogLogPlusPlusAggregationBuilder aggregationBuilder) { //执行ES聚合查询,并获取结果 //此处省略ES查询代码 //从查询结果中获取去后的数量 long uniqueCount = result.getAggregations() .get("unique_users") .getValue(); return uniqueCount; } } ``` 在上述代码中,我们使用 `AggregationBuilders.hyperLogLogPlusPlus` 方法创建了一个 HyperLogLogPlusPlusAggregationBuilder 对象,并指定了需要统计的字段名为 `user_id`。然后在 `performQueryAndGetUniqueCount` 方法中执行 ES 查询,并从查询结果中获取去后的数量。 注意:使用 HyperLogLogPlusPlusAggregationBuilder 进行基数统计时,由于它是一种基数估计算法,因此得到的结果可能存在一定的误差,但是误差范围通常比较小。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值