Skip to content
Snippets Groups Projects
SamplerAgg.md 1.15 KiB
Newer Older
Mantas's avatar
Mantas committed
# Sampler Aggregation

> More info about histogram aggregation is in the [official elasticsearch docs][1]

A filtering aggregation used to limit any sub aggregations' processing to a sample of the top-scoring documents. Optionally,
diversity settings can be used to limit the number of matches that share a common value such as an "author".

## Simple example

```JSON
{
    "aggregations": {
        "sample": {
            "sampler": {
                "shard_size": 200,
                "field" : "user.id"
            },
            "aggs": {
                 "keywords": {
                     "significant_terms": {
                         "field": "text"
                     }
                 }
            }
        }
    }
}
```

And now the query via DSL:

```php
$samplerAggregation = new SamplerAggregation('sample', 'user.id', 200);
$samplerAggregation->addAggregation(
    new SignificantTermsAggregation('keywords', 'text')
);

$search = new Search();
$search->addAggregation($samplerAggregation);

$queryArray = $search->toArray();
```

[1]: https://www.elastic.co/guide/en/elasticsearch/reference/current/search-aggregations-bucket-sampler-aggregation.html