Prisma ORM — Complete Guide
Prisma ORM — Complete Guide: free step-by-step lesson with examples, common mistakes, and interview tips — part of Next.js Tutorial on Toolliyo Academy.
On this page
Next.js Tutorial (LearnHub) · Lesson 45 of 100
Prisma ORM
Beginner ✓ → Intermediate ✓ → Advanced → Professional
Advanced · 3 — Production skills · ~18 min read · Module 5: SEO & Deploy
Introduction
This is advanced material: Prisma ORM. It is what teams use on live products. Read the example carefully and try changing one line at a time to see what happens. Prisma is a TypeScript ORM for PostgreSQL, MySQL, and SQLite. You define models in schema.prisma and query with type-safe client code. LearnHub stores users, courses, enrollments, and lesson progress. Prisma is the most common database layer in modern Next.js tutorials and startups.
An app on your laptop is not finished until students can open it on the internet.
When will you use this?
Use when you are ready to put LearnHub online for users or employers to try.
- Publishing means pushing LearnHub to Vercel, Docker, or Azure so students can access it online.
- CI/CD runs npm test and npm run build automatically on every git push.
Real-world: Practo-style clinic portal
The Healthcare team building Practo-style clinic portal uses Prisma ORM to apply Prisma ORM when building appointment booking and medical records UI. patients and doctors never see the TypeScript files — they just get a fast, reliable appointment booking and medical records UI.
Production-style code
// prisma/schema.prisma
model Course {
id String @id @default(cuid())
title String
lessons Lesson[]
}
model Lesson {
id String @id @default(cuid())
title String
courseId String
course Course @relation(fields: [courseId], references: [id])
}
// app/courses/page.tsx
import { prisma } from '@/lib/prisma';
export default async function CoursesPage() {
const courses = await prisma.course.findMany({ include: { lessons: true } });
return <CourseList courses={courses} />;
}
What happens in production: In Practo-style clinic portal, getting Prisma ORM right means patients and doctors trust the appointment booking and medical records UI every day.
Lesson example (start here)
Copy this smaller example first. Once it works, compare it with the real-world code above.
// prisma/schema.prisma
model Course {
id String @id @default(cuid())
title String
lessons Lesson[]
}
model Lesson {
id String @id @default(cuid())
title String
courseId String
course Course @relation(fields: [courseId], references: [id])
}
// app/courses/page.tsx
import { prisma } from '@/lib/prisma';
export default async function CoursesPage() {
const courses = await prisma.course.findMany({ include: { lessons: true } });
return <CourseList courses={courses} />;
}
Line-by-line walkthrough
| Code | What it means |
|---|---|
// prisma/schema.prisma | Comment — notes for humans; the compiler ignores it. |
model Course { | Part of the Prisma ORM example — read it together with the lines before and after. |
id String @id @default(cuid()) | Part of the Prisma ORM example — read it together with the lines before and after. |
title String | Part of the Prisma ORM example — read it together with the lines before and after. |
lessons Lesson[] | Part of the Prisma ORM example — read it together with the lines before and after. |
} | Closes a block started by { above. |
model Lesson { | Part of the Prisma ORM example — read it together with the lines before and after. |
id String @id @default(cuid()) | Part of the Prisma ORM example — read it together with the lines before and after. |
title String | Part of the Prisma ORM example — read it together with the lines before and after. |
courseId String | Part of the Prisma ORM example — read it together with the lines before and after. |
course Course @relation(fields: [courseId], references: [id]) | Part of the Prisma ORM example — read it together with the lines before and after. |
} | Closes a block started by { above. |
// app/courses/page.tsx | Comment — notes for humans; the compiler ignores it. |
import { prisma } from '@/lib/prisma'; | Imports a module so you can use its exports in this file. |
How it works (big picture)
- Schema defines tables and relations.
- prisma.course.findMany runs on the server inside a Server Component.
- Types flow into your components automatically.
Do this on your computer
- Run npx prisma init and define Course and Lesson models.
- Run npx prisma migrate dev.
- Create lib/prisma.ts singleton client.
- Query courses in a Server Component.
- Read the real-world section and name which part of LearnHub uses this topic.
- Run the example locally with npm run dev and confirm the same behavior.
- Change one value in the example (route, text, or course id) and predict what will happen before you save.
Experiments — try changing this
- Change a string or route in the example and save — watch the browser update.
- Break the code on purpose (remove a bracket), read the error overlay, then fix it.
- Change the API URL or course id and see how the page data changes.
- Use npm run dev while editing Prisma ORM — the page hot-reloads on save.
Remember
Prisma schema = database structure. Query in Server Components or Server Actions. Migrate schema changes with prisma migrate.
Common questions
Prisma vs raw SQL?
Prisma is faster to build with; raw SQL gives more control for complex reports.
How long should I spend on Prisma ORM?
Until you can explain it in your own words and run the example without looking at the answer. Beginners often need 30–60 minutes per new concept; setup lessons may take one afternoon.
What if I get stuck on Prisma ORM?
Re-read the line-by-line walkthrough, check the terminal and browser overlay for errors, and compare your code character-by-character with the example. Search the exact error text — someone else had it too.
Where is Prisma ORM used in real jobs?
See the real-world section above — the same pattern appears in LMS, e-commerce, SaaS, and dashboards. Interviewers ask you to explain it using one concrete example.