Gère le schéma Prisma et les migrations de Motivia. Utilise ce skill quand l'utilisateur demande de modifier la base de données, ajouter une table, un champ, une relation, ou effectuer une migration. PostgreSQL avec Prisma ORM.
prisma/schema.prisma# Développement
pnpm prisma generate # Générer le client Prisma
pnpm prisma migrate dev # Créer et appliquer une migration
pnpm prisma migrate dev --name add_feature # Migration nommée
pnpm prisma db push # Push direct (dev seulement)
# Production
pnpm prisma migrate deploy # Appliquer les migrations
# Utilitaires
pnpm prisma studio # Interface graphique
pnpm prisma db seed # Exécuter le seed
pnpm prisma format # Formater le schema
model User {
id String @id @default(cuid())
email String @unique
name String @default("")
firstName String?
lastName String?
profileTitle String?
localisation String?
image String?
emailVerified Boolean @default(false)
freeLetters Int @default(5)
keyAchievements String[]
softSkills String[]
technicalSkills String[]
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
// Relations
accounts Account[]
sessions Session[]
apiKeys ApiKey[]
experiences Experience[]
degrees Degree[]
links Link[]
projects Project[]
motivationLetters MotivationLetter[]
userCV UserCV?
}
| Modèle | Description | Relation |
|---|---|---|
| Experience | Expériences pro | User 1:N |
| Degree | Diplômes | User 1:N |
| Project | Projets portfolio | User 1:N |
| Link | Liens sociaux | User 1:N |
| MotivationLetter | Lettres générées | User 1:N |
| UserCV | CV PDF uploadé | User 1:1 |
| ApiKey | Clés API providers | User 1:N |
| Modèle | Description |
|---|---|
| Account | Comptes OAuth/credentials |
| Session | Sessions utilisateur |
| Verification | Tokens de vérification |
| Authenticator | WebAuthn |
model NouveauModele {
id String @id @default(cuid())
// ... champs métier
userId String
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
@@index([userId])
}
| Usage | Type Prisma |
|---|---|
| ID | String @id @default(cuid()) |
String @unique | |
| Texte court | String |
| Texte long | String (pas de @db.Text nécessaire) |
| Date | DateTime |
| Date optionnelle | DateTime? |
| Booléen | Boolean @default(false) |
| Entier | Int @default(0) |
| Liste de strings | String[] |
// 1:N (User a plusieurs Experience)
model User {
experiences Experience[]
}
model Experience {
userId String
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
}
// 1:1 (User a un CV)
model User {
userCV UserCV?
}
model UserCV {
userId String @unique
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
}
enum ApiProvider {
OPENAI
GOOGLE
ANTHROPIC
MISTRAL
XAI
}
model ApiKey {
provider ApiProvider
}
// prisma/schema.prisma
model User {
// Ajouter un nouveau champ
newField String?
}
pnpm prisma migrate dev --name add_new_field
app/actions/utils/schemas.tsmodel NewEntity {
id String @id @default(cuid())
name String
description String?
isActive Boolean @default(true)
userId String
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
user User @relation(fields: [userId], references: [id], onDelete: Cascade)
@@index([userId])
}
model User {
// ... existing fields
newEntities NewEntity[]
}
pnpm prisma migrate dev --name add_new_entity
Créer app/actions/new-entity.ts avec le pattern habituel.
@@index([userId]) // Toujours indexer les FK
@@index([createdAt]) // Si tri fréquent
@@unique([userId, name]) // Contrainte d'unicité
Toujours utiliser onDelete: Cascade pour les relations avec User afin de supprimer les données orphelines.
migrate devmigrate deploy (via script build)@id @default(cuid())createdAt et updatedAtuserId avec relation et onDelete: Cascade@@index([userId])