Extend Existing Models
Goals:
- Add a model at
schema.prisma
. - Extend it with the Custom Entity Builder.
Steps
💿 First, open the schema.prisma
file and add the following model:
model JobPost {
id String @id @default(cuid())
rowId String @unique
row Row @relation(fields: [rowId], references: [id], onDelete: Cascade)
title String
type String // Fixed - Hourly
budget Decimal
}
💿 On the Row model, add 2 properties:
- jobPostId - Nullable String? (not all Rows will be job posts)
- jobPost - Nullable JobPost?
model Row {
id String @id @default(cuid())
...
jobPostId String?
jobPost JobPost?
}
This property name will be important, so take note if you have jobPost
or JobPost
.
💿 Add a migration to update the database:
npx prisma migrate dev --name added_job_post_model
💿 Start your app, and add the JobPost Custom Entity.
WARNING
The name value should be the same as the one on the Row model (jobPost or JobPost).
data:image/s3,"s3://crabby-images/639fd/639fde6c99f473fb315abb0c0ad337e1a9c330fd" alt="Job Post Entity"
💿 For each field, click on Show advanced options and set Is dynamic to false
.
data:image/s3,"s3://crabby-images/a653b/a653b4cdc23a3e11ba047424fa14e603abf4206f" alt="Job Post Property is not Dynamic"
You should have at least these 3 properties:
data:image/s3,"s3://crabby-images/c4cd8/c4cd899c6afd4350eb2998664d1acb2d82a81315" alt="Job Post Properties"
💿 Add a Job Post.
data:image/s3,"s3://crabby-images/cc65b/cc65b813d7a88f8b4e5af38b6d3541e7bd88ca51" alt="New Job Post"
There will be an error, since we're trying to access the properties for an object that is not included on the database query (e.g. row.jobPost.title).
data:image/s3,"s3://crabby-images/ed4e9/ed4e97c5cedc75db5cac39d4637903b11047b358" alt="Job Post Details Error"
💿 Add the jobPost
property to the includeRowDetails constant:
export const includeRowDetails = {
+ jobPost: true,
createdByUser: true,
💿 Reload the job post.
data:image/s3,"s3://crabby-images/f5ad1/f5ad1608f2c1b2c88cdeb97da46d9095b6a52183" alt="Job Post"
💿 List all the Job Posts.
data:image/s3,"s3://crabby-images/eb547/eb547d4c693f88669898e9d14ede532530952b18" alt="Job Posts"
💿 Update all the fields.
data:image/s3,"s3://crabby-images/d9b97/d9b972832534c02fff50792a0286cf809a090a92" alt="Job Post Updated"
💿 Open a new terminal window an run prisma studio to browser the JobPosts model/table rows.
npx prisma studio
data:image/s3,"s3://crabby-images/1cb55/1cb552a3fdcda59da5a343d0c67b9455f0f6e106" alt="Job Post Prisma Studio Rows"
💿 Finally, delete the job post.
data:image/s3,"s3://crabby-images/d240e/d240e21c5ad3ba255f49d7d123a8ef5a43aec26b" alt="Job Post Deleted"
I hope this quick guide was useful! Let me know if you have any question.