55 lines
1.3 KiB
Plaintext
55 lines
1.3 KiB
Plaintext
|
[role="xpack"]
|
||
|
[testenv="basic"]
|
||
|
[[sql-functions-grouping]]
|
||
|
=== Grouping Functions
|
||
|
|
||
|
beta[]
|
||
|
|
||
|
Functions for creating special __grouping__s (also known as _bucketing_); as such these need to be used
|
||
|
as part of the <<sql-syntax-group-by, grouping>>.
|
||
|
|
||
|
[[sql-functions-grouping-histogram]]
|
||
|
==== `HISTOGRAM`
|
||
|
|
||
|
.Synopsis
|
||
|
[source, sql]
|
||
|
----
|
||
|
HISTOGRAM ( numeric_exp<1>, numeric_interval<2>)
|
||
|
HISTOGRAM ( date_exp<3>, date_time_interval<4>)
|
||
|
----
|
||
|
|
||
|
*Input*:
|
||
|
|
||
|
<1> numeric expression (typically a field)
|
||
|
<2> numeric interval
|
||
|
<3> date/time expression (typically a field)
|
||
|
<4> date/time <<sql-functions-datetime-interval, interval>>
|
||
|
|
||
|
*Output*: non-empty buckets or groups of the given expression divided according to the given interval
|
||
|
|
||
|
.Description
|
||
|
|
||
|
The histogram function takes all matching values and divides them into buckets with fixed size matching the given interval, using (roughly) the following formula:
|
||
|
|
||
|
[source, sql]
|
||
|
----
|
||
|
bucket_key = Math.floor(value / interval) * interval
|
||
|
----
|
||
|
|
||
|
`Histogram` can be applied on either numeric fields:
|
||
|
|
||
|
|
||
|
["source","sql",subs="attributes,callouts,macros"]
|
||
|
----
|
||
|
include-tagged::{sql-specs}/docs.csv-spec[histogramNumeric]
|
||
|
----
|
||
|
|
||
|
or date/time fields:
|
||
|
|
||
|
["source","sql",subs="attributes,callouts,macros"]
|
||
|
----
|
||
|
include-tagged::{sql-specs}/docs.csv-spec[histogramDate]
|
||
|
----
|
||
|
|
||
|
|