jpskill.com
🛠️ 開発・MCP コミュニティ

drizzle-orm-patterns

This skill provides comprehensive Drizzle ORM patterns for PostgreSQL with Vercel Edge Runtime support. Drizzle is Quetrex's chosen ORM because it's edge-first, type-safe, and supports all deployme...

⚡ おすすめ: コマンド1行でインストール(60秒)

下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。

🍎 Mac / 🐧 Linux
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o drizzle-orm-patterns.zip https://jpskill.com/download/17457.zip && unzip -o drizzle-orm-patterns.zip && rm drizzle-orm-patterns.zip
🪟 Windows (PowerShell)
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/17457.zip -OutFile "$d\drizzle-orm-patterns.zip"; Expand-Archive "$d\drizzle-orm-patterns.zip" -DestinationPath $d -Force; ri "$d\drizzle-orm-patterns.zip"

完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。

💾 手動でダウンロードしたい(コマンドが難しい人向け)
  1. 1. 下の青いボタンを押して drizzle-orm-patterns.zip をダウンロード
  2. 2. ZIPファイルをダブルクリックで解凍 → drizzle-orm-patterns フォルダができる
  3. 3. そのフォルダを C:\Users\あなたの名前\.claude\skills\(Win)または ~/.claude/skills/(Mac)へ移動
  4. 4. Claude Code を再起動

⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。

🎯 このSkillでできること

下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。

📦 インストール方法 (3ステップ)

  1. 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
  2. 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
  3. 3. 展開してできたフォルダを、ホームフォルダの .claude/skills/ に置く
    • · macOS / Linux: ~/.claude/skills/
    • · Windows: %USERPROFILE%\.claude\skills\

Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。

詳しい使い方ガイドを見る →
最終更新
2026-05-18
取得日時
2026-05-18
同梱ファイル
2

📖 Skill本文(日本語訳)

※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。

Drizzle ORM パターン - 完全な PostgreSQL リファレンス

用途: Quetrex でのデータベース操作、スキーマ設計、マイグレーション、またはクエリの実行時。

概要

このスキルは、Vercel Edge Runtime をサポートする PostgreSQL 向けの包括的な Drizzle ORM パターンを提供します。Drizzle は、Quetrex が選択した ORM です。なぜなら、エッジファーストであり、タイプセーフであり、すべてのデプロイメントターゲットをサポートするからです。

Drizzle を選ぶ理由

  • Edge Runtime 互換: Vercel Edge Functions、Cloudflare Workers で動作します。
  • タイプセーフ: コード生成なしで完全な TypeScript 推論が可能です。
  • 依存関係ゼロ: 重い Node.js ランタイムの要件はありません。
  • SQL ライクな API: SQL を知っている開発者には馴染みやすいです。
  • 軽量: 約 7.4kb (minify 時) (Prisma の約 300kb に対して)

スキルの構成

このスキルは、焦点を絞ったモジュールに編成されています。

1. queries-complete.md

完全なクエリパターン: select、insert、update、delete、joins、pagination、filtering、aggregations、subqueries、CTEs。

用途:

  • 任意のデータベースクエリの構築
  • フィルタを使用したデータの取得
  • レコードの挿入/更新/削除
  • ページネーションまたはソート
  • データの集計 (count、sum、avg)
  • 複雑な結合またはサブクエリ

2. transactions.md

トランザクションパターン: 分離レベル、ロールバック、ネストされたトランザクション、エラー処理、デッドロック防止。

用途:

  • 複数の操作がすべて成功する必要がある場合
  • 金融操作 (支払い、送金)
  • データ整合性の要件
  • 競合状態の防止
  • 複雑な複数ステップのワークフロー

3. relations.md

リレーションシップパターン: one-to-one、one-to-many、many-to-many、自己参照、カスケード削除、ネストされたクエリ。

用途:

  • スキーマのリレーションシップの定義
  • 関連データのクエリ
  • カスケード操作の設定
  • 階層データの操作
  • 関連データの取得の最適化

4. migrations.md

マイグレーションパターン: スキーマの進化、データマイグレーション、ゼロダウンタイムデプロイメント、ロールバック戦略。

用途:

  • データベーススキーマの追加/変更
  • スキーマ間のデータ移行
  • スキーマ変更のデプロイ
  • 問題のあるマイグレーションのロールバック
  • テーブル/カラムの名前を安全に変更

5. edge-runtime.md

エッジデプロイメントパターン: Vercel Edge Functions、Neon serverless、コネクションプーリング、HTTP ベースの接続。

用途:

  • Vercel Edge Runtime へのデプロイ
  • Neon serverless PostgreSQL の使用
  • エッジ関数のパフォーマンスの最適化
  • コネクションプーリングの設定
  • エッジの制限事項の理解

6. performance.md

パフォーマンスパターン: インデックス作成、クエリの最適化、N+1 問題の防止、バッチ操作、キャッシュ。

用途:

  • クエリが遅い場合
  • データベースの負荷が高い場合
  • N+1 クエリの問題
  • 大規模なデータセット
  • パフォーマンスの最適化が必要な場合

7. type-inference.md

TypeScript 推論パターン: InferModel、InferSelect、InferInsert、スキーマ型、カスタム型。

用途:

  • スキーマから TypeScript 型を定義
  • API 型の作成
  • タイプセーフなクエリビルダー
  • カスタム型マッパー
  • 型安全性の確保

8. common-mistakes.md

よくある落とし穴と修正: SQL インジェクションのリスク、N+1 クエリ、インデックスの欠落、トランザクションデッドロック、型エラー。

用途:

  • データベースの問題のデバッグ
  • コードレビュー
  • ベストプラクティスの学習
  • よくあるエラーの回避
  • セキュリティ監査

9. validate-queries.py

一般的なセキュリティとパフォーマンスの問題について Drizzle クエリを検証するための Python スクリプト。

用途:

  • プリコミット検証
  • セキュリティ監査
  • パフォーマンスレビュー
  • SQL インジェクションのリスクの発見
  • N+1 パターンの検出

クイックスタート

インストール

# Core packages
npm install drizzle-orm @neondatabase/serverless

# Development tools
npm install -D drizzle-kit

基本的な設定

// src/lib/db.ts
import { drizzle } from 'drizzle-orm/neon-http';
import { neon } from '@neondatabase/serverless';

const sql = neon(process.env.DATABASE_URL!);
export const db = drizzle(sql);

スキーマの定義

// src/lib/schema.ts
import { pgTable, serial, text, timestamp } from 'drizzle-orm/pg-core';

export const users = pgTable('users', {
  id: serial('id').primaryKey(),
  email: text('email').notNull().unique(),
  name: text('name').notNull(),
  createdAt: timestamp('created_at').defaultNow().notNull(),
});

基本的なクエリ

// src/services/user-service.ts
import { db } from '@/lib/db';
import { users } from '@/lib/schema';
import { eq } from 'drizzle-orm';

export async function getUserByEmail(email: string) {
  return await db.select().from(users).where(eq(users.email, email)).limit(1);
}

一般的なパターン

1. フィルタ付きの Select

import { db } from '@/lib/db';
import { users } from '@/lib/schema';
import { eq, and, gte } from 'drizzle-orm';

const activeUsers = await db
  .select()
  .from(users)
  .where(
    and(
      eq(users.status, 'active'),
      gte(users.createdAt, new Date('2024-01-01'))
    )
  );

2. Returning 付きの Insert

const [newUser] = await db
  .insert(users)
  .values({
    email: 'test@example.com',
    name: 'Test User',
  })
  .returning();

3. Returning 付きの Update

const [updatedUser] = await db
  .update(users)
  .set({ name: 'Updated Name' })
  .where(eq(users.id, 1))
  .returning();

4. トランザクション

await db.transaction(async (tx) => {
  const [user] = await tx.insert(users).values({ email, name }).returning();
  await tx.insert(profiles).values({ userId: user.id, bio });
});

5. Join クエリ

const usersWithProfiles = await db
  .select({
    userId: users.id,
    userName: users.name,
    bio: profiles.bio,
  })
  .from(users)
  .leftJoin(profiles, eq(users.id, profiles.userId));

テスト要件

すべてのデータベースコードは以下を持つ必要があります。

  • モックされたデータベースを使用したユニットテスト (90% 以上のカバレッジ)
  • テストデータベースを使用した統合テスト
  • T

(原文がここで切り詰められています)

📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開

Drizzle ORM Patterns - Complete PostgreSQL Reference

Use when: Working with database operations, schema design, migrations, or queries in Quetrex.

Overview

This skill provides comprehensive Drizzle ORM patterns for PostgreSQL with Vercel Edge Runtime support. Drizzle is Quetrex's chosen ORM because it's edge-first, type-safe, and supports all deployment targets.

Why Drizzle?

  • Edge Runtime Compatible: Works with Vercel Edge Functions, Cloudflare Workers
  • Type-Safe: Full TypeScript inference without code generation
  • Zero Dependencies: No heavy Node.js runtime requirements
  • SQL-Like API: Familiar to developers who know SQL
  • Lightweight: ~7.4kb minified (vs Prisma's ~300kb)

Skill Structure

This skill is organized into focused modules:

1. queries-complete.md

Complete query patterns: select, insert, update, delete, joins, pagination, filtering, aggregations, subqueries, CTEs.

When to use:

  • Building any database query
  • Fetching data with filters
  • Inserting/updating/deleting records
  • Pagination or sorting
  • Aggregating data (count, sum, avg)
  • Complex joins or subqueries

2. transactions.md

Transaction patterns: isolation levels, rollback, nested transactions, error handling, deadlock prevention.

When to use:

  • Multiple operations that must succeed together
  • Financial operations (payments, transfers)
  • Data consistency requirements
  • Race condition prevention
  • Complex multi-step workflows

3. relations.md

Relationship patterns: one-to-one, one-to-many, many-to-many, self-referencing, cascading deletes, nested queries.

When to use:

  • Defining schema relationships
  • Querying related data
  • Setting up cascading operations
  • Working with hierarchical data
  • Optimizing related data fetching

4. migrations.md

Migration patterns: schema evolution, data migrations, zero-downtime deployments, rollback strategies.

When to use:

  • Adding/modifying database schema
  • Migrating data between schemas
  • Deploying schema changes
  • Rolling back problematic migrations
  • Renaming tables/columns safely

5. edge-runtime.md

Edge deployment patterns: Vercel Edge Functions, Neon serverless, connection pooling, HTTP-based connections.

When to use:

  • Deploying to Vercel Edge Runtime
  • Using Neon serverless PostgreSQL
  • Optimizing edge function performance
  • Configuring connection pooling
  • Understanding edge limitations

6. performance.md

Performance patterns: indexing, query optimization, N+1 prevention, batch operations, caching.

When to use:

  • Slow queries
  • High database load
  • N+1 query problems
  • Large data sets
  • Performance optimization needed

7. type-inference.md

TypeScript inference patterns: InferModel, InferSelect, InferInsert, schema types, custom types.

When to use:

  • Defining TypeScript types from schema
  • Creating API types
  • Type-safe query builders
  • Custom type mappers
  • Ensuring type safety

8. common-mistakes.md

Common pitfalls and fixes: SQL injection risks, N+1 queries, missing indexes, transaction deadlocks, type errors.

When to use:

  • Debugging database issues
  • Code review
  • Learning best practices
  • Avoiding common errors
  • Security audits

9. validate-queries.py

Python script to validate Drizzle queries for common security and performance issues.

When to use:

  • Pre-commit validation
  • Security audits
  • Performance reviews
  • Finding SQL injection risks
  • Detecting N+1 patterns

Quick Start

Installation

# Core packages
npm install drizzle-orm @neondatabase/serverless

# Development tools
npm install -D drizzle-kit

Basic Setup

// src/lib/db.ts
import { drizzle } from 'drizzle-orm/neon-http';
import { neon } from '@neondatabase/serverless';

const sql = neon(process.env.DATABASE_URL!);
export const db = drizzle(sql);

Define Schema

// src/lib/schema.ts
import { pgTable, serial, text, timestamp } from 'drizzle-orm/pg-core';

export const users = pgTable('users', {
  id: serial('id').primaryKey(),
  email: text('email').notNull().unique(),
  name: text('name').notNull(),
  createdAt: timestamp('created_at').defaultNow().notNull(),
});

Basic Query

// src/services/user-service.ts
import { db } from '@/lib/db';
import { users } from '@/lib/schema';
import { eq } from 'drizzle-orm';

export async function getUserByEmail(email: string) {
  return await db.select().from(users).where(eq(users.email, email)).limit(1);
}

Common Patterns

1. Select with Filter

import { db } from '@/lib/db';
import { users } from '@/lib/schema';
import { eq, and, gte } from 'drizzle-orm';

const activeUsers = await db
  .select()
  .from(users)
  .where(
    and(
      eq(users.status, 'active'),
      gte(users.createdAt, new Date('2024-01-01'))
    )
  );

2. Insert with Returning

const [newUser] = await db
  .insert(users)
  .values({
    email: 'test@example.com',
    name: 'Test User',
  })
  .returning();

3. Update with Returning

const [updatedUser] = await db
  .update(users)
  .set({ name: 'Updated Name' })
  .where(eq(users.id, 1))
  .returning();

4. Transaction

await db.transaction(async (tx) => {
  const [user] = await tx.insert(users).values({ email, name }).returning();
  await tx.insert(profiles).values({ userId: user.id, bio });
});

5. Join Query

const usersWithProfiles = await db
  .select({
    userId: users.id,
    userName: users.name,
    bio: profiles.bio,
  })
  .from(users)
  .leftJoin(profiles, eq(users.id, profiles.userId));

Testing Requirements

All database code must have:

  • Unit tests with mocked database (90%+ coverage)
  • Integration tests with test database
  • Transaction rollback tests
  • Error handling tests
  • Type safety validation

Security Checklist

Before committing database code:

  • [ ] No raw SQL with string interpolation
  • [ ] All user input uses parameterized queries
  • [ ] Proper indexes on foreign keys
  • [ ] No select * in production code
  • [ ] Run python validate-queries.py on changed files
  • [ ] Transaction isolation level appropriate for use case
  • [ ] Input validation before database operations

Performance Checklist

Before committing database code:

  • [ ] Select only needed fields (avoid select *)
  • [ ] Indexes on all foreign keys
  • [ ] Indexes on frequently queried columns
  • [ ] No N+1 queries (use joins or batch loading)
  • [ ] Batch operations for multiple inserts
  • [ ] Connection pooling configured
  • [ ] Query explain analysis for complex queries

Official Resources

Migration from Prisma

If you're migrating from Prisma, see the ADR-002-DRIZZLE-ORM-MIGRATION.md decision record.

Key differences:

  • No client generation step (types inferred from schema)
  • SQL-like query builder (not Prisma's fluent API)
  • Edge Runtime compatible (Prisma 6.19.0 is not)
  • Manual relation queries (no automatic includes)

Next Steps

  1. Read queries-complete.md for all query patterns
  2. Read transactions.md for transaction safety
  3. Read relations.md for relationship patterns
  4. Run validate-queries.py on your code
  5. Review common-mistakes.md for pitfalls

Support

For Drizzle-specific questions:

For Quetrex-specific questions:

  • Check CLAUDE.md project documentation
  • Review architecture docs in /docs/architecture/
  • Ask in team Slack channel

Last Updated: 2025-11-23 by Glen Barnhardt with help from Claude Code

同梱ファイル

※ ZIPに含まれるファイル一覧。`SKILL.md` 本体に加え、参考資料・サンプル・スクリプトが入っている場合があります。