.claude/skills/prisma-client-api/SKILL.md
Prisma Client API reference covering model queries, filters, operators, and client methods. Use when writing database queries, using CRUD operations, filtering data, or configuring Prisma Client. Triggers on "prisma query", "findMany", "create", "update", "delete", "$transaction".
npx skillsauth add devkit-stack/Claude prisma-client-apiInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Complete API reference for Prisma Client. This skill provides guidance on model queries, filtering, relations, and client methods for Prisma ORM 7.x.
Reference this skill when:
import { PrismaClient } from '../generated/client'
import { PrismaPg } from '@prisma/adapter-pg'
const adapter = new PrismaPg({
connectionString: process.env.DATABASE_URL
})
const prisma = new PrismaClient({ adapter })
| Method | Description |
|--------|-------------|
| findUnique() | Find one record by unique field |
| findUniqueOrThrow() | Find one or throw error |
| findFirst() | Find first matching record |
| findFirstOrThrow() | Find first or throw error |
| findMany() | Find multiple records |
| create() | Create a new record |
| createMany() | Create multiple records |
| createManyAndReturn() | Create multiple and return them |
| update() | Update one record |
| updateMany() | Update multiple records |
| updateManyAndReturn() | Update multiple and return them |
| upsert() | Update or create record |
| delete() | Delete one record |
| deleteMany() | Delete multiple records |
| count() | Count matching records |
| aggregate() | Aggregate values (sum, avg, etc.) |
| groupBy() | Group and aggregate |
| Option | Description |
|--------|-------------|
| where | Filter conditions |
| select | Fields to include |
| include | Relations to load |
| omit | Fields to exclude |
| orderBy | Sort order |
| take | Limit results |
| skip | Skip results (pagination) |
| cursor | Cursor-based pagination |
| distinct | Unique values only |
| Method | Description |
|--------|-------------|
| $connect() | Explicitly connect to database |
| $disconnect() | Disconnect from database |
| $transaction() | Execute transaction |
| $queryRaw() | Execute raw SQL query |
| $executeRaw() | Execute raw SQL command |
| $on() | Subscribe to events |
| $extends() | Add extensions |
// Find by unique field
const user = await prisma.user.findUnique({
where: { email: '[email protected]' }
})
// Find with filter
const users = await prisma.user.findMany({
where: { role: 'ADMIN' },
orderBy: { createdAt: 'desc' },
take: 10
})
const user = await prisma.user.create({
data: {
email: '[email protected]',
name: 'Alice',
posts: {
create: { title: 'Hello World' }
}
},
include: { posts: true }
})
const user = await prisma.user.update({
where: { id: 1 },
data: { name: 'Alice Smith' }
})
await prisma.user.delete({
where: { id: 1 }
})
const [user, post] = await prisma.$transaction([
prisma.user.create({ data: { email: '[email protected]' } }),
prisma.post.create({ data: { title: 'Hello', authorId: 1 } })
])
Detailed API documentation:
rules/constructor.md - PrismaClient constructor options
rules/model-queries.md - CRUD operations
rules/query-options.md - select, include, omit, where, orderBy
rules/filters.md - Filter conditions and operators
rules/relations.md - Relation queries and nested operations
rules/transactions.md - Transaction API
rules/raw-queries.md - $queryRaw, $executeRaw
rules/client-methods.md - $connect, $disconnect, $on, $extends
| Operator | Description |
|----------|-------------|
| equals | Exact match |
| not | Not equal |
| in | In array |
| notIn | Not in array |
| lt, lte | Less than |
| gt, gte | Greater than |
| contains | String contains |
| startsWith | String starts with |
| endsWith | String ends with |
| mode | Case sensitivity |
| Operator | Description |
|----------|-------------|
| some | At least one related record matches |
| every | All related records match |
| none | No related records match |
| is | Related record matches (1-to-1) |
| isNot | Related record doesn't match |
development
Use when sending transactional emails (welcome messages, order confirmations, password resets, receipts), notifications, or bulk emails via Resend API.
development
Use when receiving emails with Resend - setting up inbound domains, processing email.received webhooks, retrieving email content/attachments, or forwarding received emails.
development
Use when setting up an email inbox for an AI agent (Moltbot, Clawdbot, or similar) - configuring inbound email, webhooks, tunneling for local development, and implementing security measures to prevent prompt injection attacks.
testing
Use when working with Resend email platform - routes to specific sub-skills for sending, receiving, audiences, or broadcasts.