forked from elastic/elasticsearch
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ESQL: Introduce per agg filter (elastic#113735)
Add support for aggregation scoped filters that work dynamically on the data in each group. | STATS success = COUNT(*) WHERE 200 <= code AND code < 300, redirect = COUNT(*) WHERE 300 <= code AND code < 400, client_err = COUNT(*) WHERE 400 <= code AND code < 500, server_err = COUNT(*) WHERE 500 <= code AND code < 600, total_count = COUNT(*) Implementation wise, the base AggregateFunction has been extended to allow a filter to be passed on. This is required to incorporate the filter as part of the aggregate equality/identify which would fail with the filter as an external component. As part of the process, the serialization for the existing aggregations had to be fixed so AggregateFunction implementations so that it delegates to their parent first.
- Loading branch information
Showing
57 changed files
with
3,181 additions
and
2,113 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
pr: 113735 | ||
summary: "ESQL: Introduce per agg filter" | ||
area: ES|QL | ||
type: feature | ||
issues: [] | ||
highlight: | ||
title: "ESQL: Introduce per agg filter" | ||
body: |- | ||
Add support for aggregation scoped filters that work dynamically on the | ||
data in each group. | ||
[source,esql] | ||
---- | ||
| STATS success = COUNT(*) WHERE 200 <= code AND code < 300, | ||
redirect = COUNT(*) WHERE 300 <= code AND code < 400, | ||
client_err = COUNT(*) WHERE 400 <= code AND code < 500, | ||
server_err = COUNT(*) WHERE 500 <= code AND code < 600, | ||
total_count = COUNT(*) | ||
---- | ||
Implementation wise, the base AggregateFunction has been extended to | ||
allow a filter to be passed on. This is required to incorporate the | ||
filter as part of the aggregate equality/identity which would fail with | ||
the filter as an external component. | ||
As part of the process, the serialization for the existing aggregations | ||
had to be fixed so AggregateFunction implementations so that it | ||
delegates to their parent first. | ||
notable: true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.