2020-01-14 15:57:45 +03:00
|
|
|
|
.. meta::
|
|
|
|
|
:description: Make nested object queries in Hasura
|
|
|
|
|
:keywords: hasura, docs, query, nested object query
|
|
|
|
|
|
2018-09-11 14:11:24 +03:00
|
|
|
|
Nested object queries
|
|
|
|
|
=====================
|
|
|
|
|
|
2018-12-03 15:12:24 +03:00
|
|
|
|
.. contents:: Table of contents
|
|
|
|
|
:backlinks: none
|
2019-09-05 17:53:50 +03:00
|
|
|
|
:depth: 2
|
2018-12-03 15:12:24 +03:00
|
|
|
|
:local:
|
|
|
|
|
|
2018-09-11 14:11:24 +03:00
|
|
|
|
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.
|
|
|
|
|
|
2019-04-19 13:48:18 +03:00
|
|
|
|
The **name of the nested object** is the same as the name of the object/array relationship configured in
|
|
|
|
|
the console.
|
|
|
|
|
|
|
|
|
|
You can also filter, sort, aggregate and paginate nested objects in case of array relationships. These are not exposed
|
|
|
|
|
for object relationships as they have only one nested object.
|
2018-11-15 14:43:03 +03:00
|
|
|
|
|
2018-12-03 15:12:24 +03:00
|
|
|
|
Fetch nested object using an object relationship
|
|
|
|
|
------------------------------------------------
|
2018-12-17 14:58:29 +03:00
|
|
|
|
The following is an example of a nested object query using the **object relationship** between an article and an
|
2018-11-15 14:43:03 +03:00
|
|
|
|
author.
|
|
|
|
|
|
2019-04-19 13:48:18 +03:00
|
|
|
|
**Example:** Fetch a list of articles and the name of each article’s author:
|
2018-11-15 14:43:03 +03:00
|
|
|
|
|
|
|
|
|
.. 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"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-12-03 15:12:24 +03:00
|
|
|
|
Fetch nested objects using an array relationship
|
|
|
|
|
------------------------------------------------
|
2018-12-17 14:58:29 +03:00
|
|
|
|
The following is an example of a nested object query using the **array relationship** between an author and
|
2018-09-11 14:11:24 +03:00
|
|
|
|
articles.
|
|
|
|
|
|
2019-04-19 13:48:18 +03:00
|
|
|
|
**Example:** Fetch a list of authors and a nested list of each author’s articles:
|
2018-09-11 14:11:24 +03:00
|
|
|
|
|
|
|
|
|
.. 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"
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2018-11-15 14:43:03 +03:00
|
|
|
|
.. note::
|
|
|
|
|
|
2019-04-19 13:48:18 +03:00
|
|
|
|
You can also :ref:`filter <nested_filter>`, :ref:`sort <nested_sort>`, :ref:`aggregate <nested_aggregate>`
|
2019-09-11 10:17:14 +03:00
|
|
|
|
and :ref:`paginate <nested_paginate>` nested objects in case of array relationships.
|