Modelling one-to-many table relationships¶
Table of contents
A one-to-many
relationship between two tables can be established via a foreign key constraint.
Say we have the following two tables in our database schema:
author (
id SERIAL PRIMARY KEY,
name TEXT
)
article (
id SERIAL PRIMARY KEY,
author_id INT
title TEXT
...
)
These two tables are related via a one-to-many
relationship. i.e:
- an
author
can have manyarticles
- an
article
has oneauthor
Set up a table relationship in the database¶
This one-to-many
relationship can be established in the database by:
- Adding a foreign key constraint from the
article
table to theauthor
table using theauthor_id
andid
columns of the tables respectively.
This will ensure that the value of author_id
column in the article
table is present in the id
column of
the author
table.
Set up GraphQL relationships¶
To access the nested objects via the GraphQL API, create the following relationships:
- Array relationship,
articles
fromauthor
table usingarticle :: author_id -> id
- Object relationship,
author
fromarticle
table usingauthor_id -> author :: id
Query using relationships¶
We can now:
fetch a list of authors with their
articles
:query { author { id name articles { id title } } }
query { author { id name articles { id title } } }{ "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" } ] } ] } }fetch a list of articles with their
author
:query { article { id title author { id name } } }
query { article { id title author { id name } } }{ "data": { "article": [ { "id": 1, "title": "sit amet", "author": { "id": 4, "name": "Anjela" } }, { "id": 2, "title": "a nibh", "author": { "id": 2, "name": "Beltran" } } ] } }
Was this page helpful?
Stay up to date with product & security news