Agent skill
db-schema-change
Handle Drizzle database schema changes safely. Generate and apply migrations, add tables and columns. Use when modifying database schema, adding tables, creating migrations, or making database changes.
Install this agent skill to your Project
npx add-skill https://github.com/majiayu000/claude-skill-registry/tree/main/skills/data/db-schema-change
SKILL.md
Database Schema Change
Safely modify PostgreSQL schema using Drizzle ORM.
When to Use
- "Add a new table for..."
- "Add column to..."
- "Create migration for..."
- "Modify database schema"
- "Add foreign key to..."
Important Files
| File | Purpose |
|---|---|
packages/db/src/schema.ts |
Main schema exports |
packages/db/src/auth-schema.ts |
Better Auth tables |
packages/db/src/rag-schema.ts |
RAG embeddings tables |
packages/db/drizzle/ |
Generated migrations |
Procedure
Step 1: Understand Current Schema
Read the schema file to understand existing tables:
Read: packages/db/src/schema.ts
Step 2: Plan the Change
Before making changes, confirm with user:
- Table name and column definitions
- Data types (see types.md)
- Relationships (foreign keys)
- Indexes needed
- Whether data migration is required
Step 3: Modify Schema
Edit the appropriate schema file:
// packages/db/src/schema.ts
import { pgTable, text, timestamp, uuid } from 'drizzle-orm/pg-core';
export const newTable = pgTable('new_table', {
id: uuid('id').primaryKey().defaultRandom(),
name: text('name').notNull(),
createdAt: timestamp('created_at').defaultNow().notNull(),
updatedAt: timestamp('updated_at').defaultNow().notNull(),
});
Step 4: Generate Migration
Run migration generator:
pnpm -C packages/db migrate:generate
Step 5: Review Migration
Read the generated migration in packages/db/drizzle/ and verify:
- Correct SQL statements
- No data loss for existing tables
- Proper indexes created
Step 6: Apply Migration (Local)
pnpm -C packages/db migrate:apply
Step 7: Verify
pnpm typecheck
pnpm lint
Checklist
- Schema change planned with user
- Schema file updated
- Migration generated
- Migration reviewed (no data loss)
- Migration applied locally
- TypeScript compiles
- Existing tests still pass
Guardrails
- NEVER drop columns without explicit user confirmation
- NEVER run migrations on production directly (CI handles this)
- ALWAYS generate migration before applying
- ALWAYS review generated SQL before applying
- If migration involves data transformation, create separate script
- Ask user before destructive changes (DROP, TRUNCATE)
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
agent-ops-spec
Manage specification documents in .agent/specs/. Use when user provides requirements, acceptance criteria, or feature descriptions that need to be tracked and validated against implementation.
agent-ops-state
Maintain .agent state files. Use at session start, after meaningful steps, and before concluding: read/update constitution/memory/focus/issues/baseline consistently.
agent-ops-spec
Manage specification documents in .agent/specs/. Use when user provides requirements, acceptance criteria, or feature descriptions that need to be tracked and validated against implementation.
agent-ops-testing
Test strategy, execution, and coverage analysis. Use when designing tests, running test suites, or analyzing test results beyond baseline checks.
agent-ops-testing
Test strategy, execution, and coverage analysis. Use when designing tests, running test suites, or analyzing test results beyond baseline checks.
agent-ops-state
Maintain .agent state files. Use at session start, after meaningful steps, and before concluding: read/update constitution/memory/focus/issues/baseline consistently.
Didn't find tool you were looking for?