2018-11-15 14:43:03 +03:00
|
|
|
Aggregation queries
|
|
|
|
===================
|
|
|
|
|
2018-12-03 15:12:24 +03:00
|
|
|
.. contents:: Table of contents
|
|
|
|
:backlinks: none
|
|
|
|
:depth: 1
|
|
|
|
:local:
|
|
|
|
|
2018-11-15 14:43:03 +03:00
|
|
|
You can fetch aggregations on columns along with nodes using an aggregation query.
|
2018-12-17 14:58:29 +03:00
|
|
|
Available aggregation functions are ``count``, ``sum``, ``avg``, ``max`` and ``min``.
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
|
|
The name of the :ref:`aggregate field <aggregate_object>` is of the form ``field-name + _aggregate``
|
2018-11-15 14:43:03 +03:00
|
|
|
|
2018-12-03 15:12:24 +03:00
|
|
|
Fetch aggregated data of an object
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
For example, fetch a list of articles with aggregated data of their rating:
|
2018-11-15 14:43:03 +03:00
|
|
|
|
|
|
|
.. graphiql::
|
|
|
|
:view_only:
|
|
|
|
:query:
|
|
|
|
query {
|
|
|
|
article_aggregate {
|
|
|
|
aggregate {
|
|
|
|
count
|
|
|
|
sum {
|
|
|
|
rating
|
|
|
|
}
|
|
|
|
avg {
|
|
|
|
rating
|
|
|
|
}
|
|
|
|
max {
|
|
|
|
rating
|
|
|
|
}
|
|
|
|
}
|
|
|
|
nodes {
|
|
|
|
id
|
|
|
|
title
|
|
|
|
rating
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
:response:
|
|
|
|
{
|
|
|
|
"data": {
|
|
|
|
"article_aggregate": {
|
|
|
|
"aggregate": {
|
|
|
|
"count": 10,
|
|
|
|
"sum": {
|
|
|
|
"rating": 26
|
|
|
|
},
|
|
|
|
"avg": {
|
|
|
|
"rating": 2.6
|
|
|
|
},
|
|
|
|
"max": {
|
|
|
|
"rating": 4
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"nodes": [
|
|
|
|
{
|
|
|
|
"id": 1,
|
|
|
|
"title": "sit amet",
|
|
|
|
"rating": 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 2,
|
|
|
|
"title": "a nibh",
|
|
|
|
"rating": 3
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 3,
|
|
|
|
"title": "amet justo morbi",
|
|
|
|
"rating": 4
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 4,
|
|
|
|
"title": "vestibulum ac est",
|
|
|
|
"rating": 2
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 5,
|
|
|
|
"title": "ut blandit",
|
|
|
|
"rating": 2
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 6,
|
|
|
|
"title": "sapien ut",
|
|
|
|
"rating": 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 7,
|
|
|
|
"title": "nisl duis ac",
|
|
|
|
"rating": 4
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 8,
|
|
|
|
"title": "donec semper sapien",
|
|
|
|
"rating": 3
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 9,
|
|
|
|
"title": "sit amet",
|
|
|
|
"rating": 3
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 10,
|
|
|
|
"title": "dui proin leo",
|
|
|
|
"rating": 3
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-03 15:12:24 +03:00
|
|
|
Fetch aggregated data on nested objects
|
|
|
|
---------------------------------------
|
2018-12-17 14:58:29 +03:00
|
|
|
The following is an example of a nested object query with aggregations on the **array relationship** between an author
|
|
|
|
and articles.
|
2018-11-15 14:43:03 +03:00
|
|
|
|
2018-12-17 14:58:29 +03:00
|
|
|
Fetch an author whose id is ``1`` and a nested list of articles with aggregated data of their rating:
|
2018-11-15 14:43:03 +03:00
|
|
|
|
|
|
|
.. graphiql::
|
|
|
|
:view_only:
|
|
|
|
:query:
|
|
|
|
query {
|
|
|
|
author (where: {id: {_eq: 1}}) {
|
|
|
|
id
|
|
|
|
name
|
|
|
|
articles_aggregate {
|
|
|
|
aggregate {
|
|
|
|
count
|
|
|
|
avg {
|
|
|
|
rating
|
|
|
|
}
|
|
|
|
max {
|
|
|
|
rating
|
|
|
|
}
|
|
|
|
}
|
|
|
|
nodes {
|
|
|
|
id
|
|
|
|
title
|
|
|
|
rating
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
:response:
|
|
|
|
{
|
|
|
|
"data": {
|
|
|
|
"author": [
|
|
|
|
{
|
|
|
|
"id": 1,
|
|
|
|
"name": "Justin",
|
|
|
|
"articles_aggregate": {
|
|
|
|
"aggregate": {
|
|
|
|
"count": 2,
|
|
|
|
"avg": {
|
|
|
|
"rating": 2.5
|
|
|
|
},
|
|
|
|
"max": {
|
|
|
|
"rating": 4
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"nodes": [
|
|
|
|
{
|
|
|
|
"id": 15,
|
|
|
|
"title": "vel dapibus at",
|
|
|
|
"rating": 4
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"id": 16,
|
|
|
|
"title": "sem duis aliquam",
|
|
|
|
"rating": 1
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|