티스토리 뷰
반응형
✅ Prisma + REST API 통합 가이드 – Express 기반 실전 예제
"Prisma로 타입 안정성과 생산성을 모두 잡고, Express로 REST API를 구축하자."
NestJS든 Express든 Prisma는 완벽하게 통합됩니다.
🎯 목표
- Express 기반 REST API 서버에 Prisma ORM을 도입
- 사용자(User) 생성 및 조회 API 구현
- TypeScript + PostgreSQL + Prisma 조합
📦 1. 프로젝트 기본 세팅
mkdir prisma-rest-api && cd prisma-rest-api
npm init -y
npm install express @prisma/client
npm install prisma --save-dev
npm install typescript ts-node @types/node @types/express --save-dev
tsconfig.json 생성:
{
"compilerOptions": {
"target": "es2019",
"module": "commonjs",
"strict": true,
"outDir": "dist",
"esModuleInterop": true
},
"include": ["src"]
}
📐 2. Prisma 설정 및 DB 모델 정의
npx prisma init
.env 설정:
DATABASE_URL="postgresql://user:password@localhost:5432/mydb"
prisma/schema.prisma:
generator client {
provider = "prisma-client-js"
}
datasource db {
provider = "postgresql"
url = env("DATABASE_URL")
}
model User {
id Int @id @default(autoincrement())
name String
email String @unique
}
마이그레이션 적용:
npx prisma migrate dev --name init
🔧 3. Express API 작성
반응형
src/prisma.ts – Prisma Client 인스턴스
import { PrismaClient } from '@prisma/client'
const prisma = new PrismaClient()
export default prisma
src/server.ts – 서버 및 라우터 설정
import express from 'express'
import prisma from './prisma'
const app = express()
app.use(express.json())
// 사용자 생성
app.post('/users', async (req, res) => {
const { name, email } = req.body
const user = await prisma.user.create({
data: { name, email },
})
res.json(user)
})
// 사용자 목록
app.get('/users', async (_req, res) => {
const users = await prisma.user.findMany()
res.json(users)
})
app.listen(3000, () => {
console.log('🚀 Server running on http://localhost:3000')
})
▶️ 실행
npx ts-node src/server.ts
- POST http://localhost:3000/users
- { "name": "훈창", "email": "hoon@example.com" }
- GET http://localhost:3000/users
→ 사용자 목록 반환
✅ Prisma + REST API 연동 핵심 요약
항목 내용
Client 생성 | new PrismaClient() 사용 |
타입 자동완성 | .user.findMany() 등 완벽한 IntelliSense |
마이그레이션 | prisma migrate dev 로 관리 |
실무 적용 | Express / NestJS / Fastify 등 자유롭게 연동 가능 |
🧠 실무 팁
- Prisma Client는 앱 전체에서 싱글톤으로 관리하는 것이 안정적
- prisma.$disconnect()는 서버 종료 시 명시적으로 호출 필요
- CRUD 외에도 .count(), .aggregate(), .transaction() 등 확장 기능 풍부
Prisma REST API,Prisma Express 연동,TypeScript Express Prisma,Prisma PostgreSQL 예제,Node.js ORM REST,Prisma로 CRUD 만들기,REST API ORM 통합,Prisma 서버 구축,Prisma Client 사용법,Prisma 실무 예제
'framework > Prisma' 카테고리의 다른 글
✅ Prisma + 풀스택 개발 통합 가이드 – Next.js 기반 실전 예제 (0) | 2025.04.29 |
---|---|
✅ Prisma + GraphQL 통합 가이드 – TypeScript 기반 실전 예제 (1) | 2025.04.28 |
✅ Prisma에서 데이터 모델링하기 – 관계형 DB를 위한 실전 가이드 (0) | 2025.04.23 |
✅ 내 프로젝트에 Prisma를 써야 할까? – 도입 전 반드시 확인해야 할 체크리스트 (0) | 2025.04.22 |
✅ 왜 Prisma인가? – 기존 ORM을 뛰어넘는 Prisma의 6가지 이유 (0) | 2025.04.18 |
※ 이 포스팅은 쿠팡 파트너스 활동의 일환으로, 이에 따른 일정액의 수수료를 제공받습니다.
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- App Router
- AI챗봇
- fastapi
- Next.js
- seo 최적화 10개
- CI/CD
- 프론트엔드
- rag
- Webpack
- Docker
- REACT
- 개발블로그
- nextJS
- 관리자
- 웹개발
- gatsbyjs
- Ktor
- 프론트엔드면접
- Prisma
- nodejs
- LangChain
- kotlin
- SEO 최적화
- PostgreSQL
- llm
- NestJS
- Python
- SEO최적화
- github
- 백엔드개발
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | ||||
4 | 5 | 6 | 7 | 8 | 9 | 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 |
18 | 19 | 20 | 21 | 22 | 23 | 24 |
25 | 26 | 27 | 28 | 29 | 30 | 31 |
글 보관함
반응형