mirror of
https://github.com/hasura/graphql-engine.git
synced 2024-12-17 20:41:49 +03:00
207 lines
4.4 KiB
ReStructuredText
207 lines
4.4 KiB
ReStructuredText
Nested object queries
|
||
=====================
|
||
|
||
.. contents:: Table of contents
|
||
:backlinks: none
|
||
:depth: 1
|
||
:local:
|
||
|
||
You can use the object (one-to-one) or array (one-to-many) :doc:`relationships <../schema/relationships/index>` defined
|
||
in your schema to make a nested query i.e. fetch data for a type along with data from a nested or related type.
|
||
|
||
|
||
Fetch nested object using an object relationship
|
||
------------------------------------------------
|
||
The following is an example of a nested object query using the ``object relationship`` between an article and an
|
||
author.
|
||
|
||
Fetch a list of articles and the name of each article’s author:
|
||
|
||
.. graphiql::
|
||
:view_only:
|
||
:query:
|
||
query {
|
||
article {
|
||
id
|
||
title
|
||
author {
|
||
name
|
||
}
|
||
}
|
||
}
|
||
:response:
|
||
{
|
||
"data": {
|
||
"article": [
|
||
{
|
||
"id": 1,
|
||
"title": "sit amet",
|
||
"author": {
|
||
"name": "Anjela"
|
||
}
|
||
},
|
||
{
|
||
"id": 2,
|
||
"title": "a nibh",
|
||
"author": {
|
||
"name": "Beltran"
|
||
}
|
||
},
|
||
{
|
||
"id": 3,
|
||
"title": "amet justo morbi",
|
||
"author": {
|
||
"name": "Anjela"
|
||
}
|
||
}
|
||
]
|
||
}
|
||
}
|
||
|
||
Fetch nested objects using an array relationship
|
||
------------------------------------------------
|
||
The following is an example of a nested object query using the ``array relationship`` between an author and
|
||
articles.
|
||
|
||
Fetch a list of authors and a nested list of each author’s articles:
|
||
|
||
.. graphiql::
|
||
:view_only:
|
||
:query:
|
||
query {
|
||
author {
|
||
id
|
||
name
|
||
articles {
|
||
id
|
||
title
|
||
}
|
||
}
|
||
}
|
||
:response:
|
||
{
|
||
"data": {
|
||
"author": [
|
||
{
|
||
"id": 1,
|
||
"name": "Justin",
|
||
"articles": [
|
||
{
|
||
"id": 15,
|
||
"title": "vel dapibus at"
|
||
},
|
||
{
|
||
"id": 16,
|
||
"title": "sem duis aliquam"
|
||
}
|
||
]
|
||
},
|
||
{
|
||
"id": 2,
|
||
"name": "Beltran",
|
||
"articles": [
|
||
{
|
||
"id": 2,
|
||
"title": "a nibh"
|
||
},
|
||
{
|
||
"id": 9,
|
||
"title": "sit amet"
|
||
}
|
||
]
|
||
},
|
||
{
|
||
"id": 3,
|
||
"name": "Sidney",
|
||
"articles": [
|
||
{
|
||
"id": 6,
|
||
"title": "sapien ut"
|
||
},
|
||
{
|
||
"id": 11,
|
||
"title": "turpis eget"
|
||
},
|
||
{
|
||
"id": 14,
|
||
"title": "congue etiam justo"
|
||
}
|
||
]
|
||
}
|
||
]
|
||
}
|
||
}
|
||
|
||
|
||
.. note::
|
||
|
||
The name of the nested object is the same as the name of the object or array relationship configured in the
|
||
console.
|
||
|
||
Fetch aggregated data on nested objects
|
||
---------------------------------------
|
||
The following is an example of a nested object query with aggregations on array relationship between author and
|
||
articles.
|
||
|
||
Fetch an author whose id is ``1`` and a nested list of articles with aggregated rating data:
|
||
|
||
.. 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
|
||
}
|
||
]
|
||
}
|
||
}
|
||
]
|
||
}
|
||
}
|