Learn how to summarize or "aggregate" data with cbElasticsearch
In some cases, you aren't interested in searching documents as you are in retrieving specific information stored within each document. It is for such a purpose that Elasticsearch provides the ability to aggregate, or summarize, index data.
Creating an Aggregation
cbElasticsearch's SearchBuilder provides an aggregation() method for simple aggregation definitions:
To run the query and retrieve aggregations, call searchBuilder.execute() followed by getAggregations(). getAggregations() will return a key/value struct where the key is your provided aggregation name:
var data =mySearch.aggregation( "last_updated",{"max":{"field":"meta.timestamp"}} ).execute().getAggregations()[ "last_updated" ];
For a simple metrics aggregation, you should be able to use the value or value_as_string keys of the returned aggregation:
In contrast, bucket aggregations return a buckets array which can be used as-is or mapped into a separate result entirely: