Babysitter drizzle

Drizzle ORM patterns, migrations, type-safe queries, and database schema design.

install
source · Clone the upstream repo
git clone https://github.com/a5c-ai/babysitter
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/a5c-ai/babysitter "$T" && mkdir -p ~/.claude/skills && cp -r "$T/library/specializations/web-development/skills/drizzle" ~/.claude/skills/a5c-ai-babysitter-drizzle && rm -rf "$T"
manifest: library/specializations/web-development/skills/drizzle/SKILL.md
source content

Drizzle Skill

Expert assistance for database operations with Drizzle ORM.

Capabilities

  • Define type-safe database schemas
  • Write performant SQL queries
  • Handle migrations
  • Implement relations
  • Configure multiple database dialects

Schema Definition

import { pgTable, text, timestamp, uuid, varchar } from 'drizzle-orm/pg-core';
import { relations } from 'drizzle-orm';

export const users = pgTable('users', {
  id: uuid('id').primaryKey().defaultRandom(),
  name: varchar('name', { length: 255 }).notNull(),
  email: varchar('email', { length: 255 }).notNull().unique(),
  createdAt: timestamp('created_at').defaultNow().notNull(),
});

export const posts = pgTable('posts', {
  id: uuid('id').primaryKey().defaultRandom(),
  title: varchar('title', { length: 255 }).notNull(),
  content: text('content'),
  authorId: uuid('author_id').references(() => users.id),
});

export const usersRelations = relations(users, ({ many }) => ({
  posts: many(posts),
}));

Queries

// Select with relations
const result = await db.query.users.findMany({
  with: { posts: true },
  where: eq(users.name, 'John'),
});

// Insert
await db.insert(users).values({ name: 'John', email: 'john@example.com' });

// Update
await db.update(users).set({ name: 'Jane' }).where(eq(users.id, id));

Target Processes

  • database-setup
  • backend-development
  • nextjs-full-stack