Effortless request-scoped Prisma DataLoaders for NestJS.
Avoid N+1 problems and optimize your database queries with ease.
npm install nestjs-prisma-dataloaderThis package integrates DataLoader with Prisma and NestJS, making it easy to batch and cache Prisma queries per request. It’s ideal for GraphQL and REST APIs where you want to avoid repeated database calls for the same data.
- 🔁 Request-scoped caching for DataLoader
- 📦 Plug and play module for NestJS
- 📚 Supports batching and caching for Prisma queries
- 💡 Auto-cleared on each request – no stale data
- 📐 Typescript-ready with clear typings
// app.module.ts
import { Module } from '@nestjs/common';
import { DataloaderModule } from 'nestjs-prisma-dataloader';
@Module({
imports: [DataloaderModule],
})
export class AppModule {}// user.service.ts
import { Injectable } from '@nestjs/common';
import { DataloaderService } from 'nestjs-prisma-dataloader';
@Injectable()
export class UserService {
constructor(private readonly dataloader: DataloaderService) {}
async getUsers(userIds: number[]) {
const userLoader = this.dataloader.getLoader('user');
return await userLoader.loadMany(userIds);
}
}📌 Note: 'user' here should match the key you’ve configured in the DataloaderService (default or customized).
- In GraphQL resolvers to prevent N+1 queries
- In REST endpoints where the same record is queried multiple times
- When you want per-request caching in a Prisma + NestJS project
- If you're not using Prisma
- In background workers or CLI scripts (non-request context)
- When your ORM queries are already optimized using relations or joins
- Make sure DataloaderService is request-scoped
- Always match loader keys exactly
- This package does not auto-generate loaders — you define them
MIT
Made with ❤️ for NestJS + Prisma developers