๐ Add authors details to the books collection
๐ Add author name to the books collectionโ
We want to modify the MongoDB schema so that each book contains an array of its authors. Right now in the authorBooks
mapping we're getting the authorId
for the current book, but we want also the name of the author. So in this step we will embed the author name into array created from the mapping of the join table (which right now only contains authorId
and bookId
)
- On the MongoDB diagram view, click the
books
collection - On the relational mappings list on the right, click
+ Add
- Select
Embedded documents
- Select
authors
as Source table - In the advanced settings, check 'Merge fields into parent`
- Check the
name
field and uncheck the rest - Click
Save and close
data:image/s3,"s3://crabby-images/7241c/7241c5510b9a52e36b3ee05d50d3c4d42a99ac06" alt="Changes in the books collection"
๐ Remove unneeded bookId from author details in books collectionโ
We want to modify the MongoDB schema so that each book contains an array of its authors.
In this step we will remove the redundant ID fields from the join table (that you can see in authorBooks
at the moment).
- On the MongoDB diagram view, click the
books
collection. - On the relational mappings list on the right, click on the edit icon of
author_book
. - Edit the field name from
authorBooks
to justauthors
. - In the list of fields, uncheck
bookId
. - Click
Save and close
.
This results in our authors
array looking like:
"authors": [
{
"authorId": 8282,
"name": "Cervantes"
},
...
]
data:image/s3,"s3://crabby-images/44d7e/44d7ed3e43108af74db2ef3a0ebb2410e0c9ef36" alt="Changes in the books collection"
This is a perfect example of the Extended Reference Pattern. When we read a book, we have some of the author's data (name
in this case) but we still have the author's id in case we need all the author's attributes (we can then do a join on read using $lookup
)