Réinitialisation et Ensemencement de Base de Données

VérifiéPrudence

Cette compétence réinitialise une base de données à un état vierge et la remplit éventuellement avec des données de test. Elle fonctionne avec MongoDB et PostgreSQL, exécute une sauvegarde, supprime la base, applique les migrations et insère les données. Utilisez-la lorsque vous avez besoin d’une base de données fraîche pour le développement ou les tests après des migrations.

Spar Skills Guide Bot
DeveloppementIntermédiaire
15002/06/2026
Claude Code
#database#reset#seed#migration#development

Recommandé pour

Notre avis

Réinitialise et remplit une base de données de développement avec des données de test, en incluant une sauvegarde préalable.

Points forts

  • Prend en charge MongoDB et PostgreSQL
  • Gère automatiquement les sauvegardes avant réinitialisation
  • Execute les migrations et le seed via des scripts configurés

Limites

  • Ne fonctionne que pour les projets listés dans la configuration
  • Ne gère pas les bases de données cloud ou distantes
  • Requiert que les outils CLI (mongodump, psql, Prisma) soient installés
Quand l'utiliser

Lorsque vous avez besoin d'un état de base de données frais et cohérent pour le développement ou les tests.

Quand l'éviter

Ne jamais utiliser en production ; pour des besoins de migration simples sans reset, préférez une commande de migration seule.

Analyse de sécurité

Prudence
Score qualité90/100

Uses bash to execute database management commands, including destructive operations like dropping databases. Skill includes warnings to avoid production use and suggests backup, but the operations are powerful and could cause data loss if misapplied.

Aucun point d'attention détecté

Exemples

Reset database for eruditiontx-services-mvp
Reset and seed the database for eruditiontx-services-mvp
Reset database for a Prisma project
Reset the database for notaryo.ph with fresh seed data
General database reset with confirmation
Reset the current project's database and seed it with test data

name: db-reset description: Reset and seed database for development or testing. Use when needing fresh database state, running migrations, or seeding test data. argument-hint: [project-name] disable-model-invocation: true allowed-tools: Bash, Read, Glob

Database Reset & Seed

Reset databases to a clean state and optionally seed with test data.

Arguments

  • $ARGUMENTS: Project name (optional - uses current directory if not specified)

IMPORTANT WARNINGS

  • NEVER run on production databases
  • Always backup before reset
  • Confirm with user before destructive operations

Database Configurations

| Project | Database | Connection | Seed Script | |---------|----------|------------|-------------| | eruditiontx-services-mvp | MongoDB | mongodb://localhost:27017/eruditiontx_db | scripts/seed.py | | mathmatterstx-services | MongoDB | mongodb://localhost:27017/mathmatters_db | scripts/seed.py | | notaryo.ph | PostgreSQL | .env.local DATABASE_URL | prisma/seed.ts | | bocs-turbo | Various | Per app config | Per app |

Execution Steps

1. Backup Current Database

MongoDB:

mongodump --db=$DB_NAME --out=./backup/$(date +%Y%m%d_%H%M%S)

PostgreSQL:

pg_dump $DATABASE_URL > ./backup/$(date +%Y%m%d_%H%M%S).sql

2. Reset Database

MongoDB:

mongosh --eval "use $DB_NAME; db.dropDatabase();"
# or with authentication
mongosh mongodb://localhost:27017/$DB_NAME --eval "db.dropDatabase();"

PostgreSQL (Prisma):

npx prisma migrate reset --force
# This drops, recreates, and runs all migrations

3. Run Migrations

MongoDB (Beanie): Beanie auto-creates collections from models. No explicit migration needed.

PostgreSQL (Prisma):

npx prisma migrate deploy
# or for development
npx prisma migrate dev

4. Seed Database

Python Projects:

# If seed script exists
uv run python scripts/seed.py
# or
uv run python -m app.database.seed

Prisma Projects:

npx prisma db seed
# Runs the seed script defined in package.json

Test Database Reset

For running tests with clean database:

Python (pytest):

# Create test database
mongosh --eval "use eruditiontx_test_db; db.dropDatabase();"

# Run tests (they should seed their own fixtures)
uv run pytest --db-reset

JavaScript:

# Usually handled by test setup
npm run test:db-reset

Common Seed Data

User Roles (Erudition Projects)

  • Admin users
  • Staff users
  • Teacher users
  • Student users

Sample Data

  • Test schools/organizations
  • Sample questions/content
  • Test transactions

Output Format

Database Reset: [project-name]
Database Type: [MongoDB/PostgreSQL]
Database Name: [db-name]

1. Creating backup...
   Backup saved: ./backup/[timestamp]

2. Dropping database...
   Database dropped.

3. Running migrations...
   [Migration output]

4. Seeding data...
   [Seed output]

Database reset complete!
Records created:
  - Users: X
  - [Other models]: Y

Recovery

If something goes wrong:

# MongoDB
mongorestore --db=$DB_NAME ./backup/[timestamp]/$DB_NAME

# PostgreSQL
psql $DATABASE_URL < ./backup/[timestamp].sql
Skills similaires