2014-05-15 06:36:05 -04:00
|
|
|
[[java-aggs-metrics-cardinality]]
|
|
|
|
==== Cardinality Aggregation
|
|
|
|
|
|
|
|
Here is how you can use
|
|
|
|
{ref}/search-aggregations-metrics-cardinality-aggregation.html[Cardinality Aggregation]
|
|
|
|
with Java API.
|
|
|
|
|
|
|
|
|
|
|
|
===== Prepare aggregation request
|
|
|
|
|
|
|
|
Here is an example on how to create the aggregation request:
|
|
|
|
|
|
|
|
[source,java]
|
|
|
|
--------------------------------------------------
|
2016-11-28 11:33:40 -05:00
|
|
|
CardinalityAggregationBuilder aggregation =
|
2014-05-15 06:36:05 -04:00
|
|
|
AggregationBuilders
|
|
|
|
.cardinality("agg")
|
|
|
|
.field("tags");
|
|
|
|
--------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
===== Use aggregation response
|
|
|
|
|
|
|
|
Import Aggregation definition classes:
|
|
|
|
|
|
|
|
[source,java]
|
|
|
|
--------------------------------------------------
|
|
|
|
import org.elasticsearch.search.aggregations.metrics.cardinality.Cardinality;
|
|
|
|
--------------------------------------------------
|
|
|
|
|
|
|
|
[source,java]
|
|
|
|
--------------------------------------------------
|
|
|
|
// sr is here your SearchResponse object
|
|
|
|
Cardinality agg = sr.getAggregations().get("agg");
|
|
|
|
long value = agg.getValue();
|
|
|
|
--------------------------------------------------
|
|
|
|
|
|
|
|
|