Claude-skill-registry drizzle-orm
Enforces project Drizzle ORM coding conventions when creating or modifying database queries, schemas, and migrations. This skill ensures consistent patterns for query structure, type safety, permission filtering, pagination, resilience, and database operations.
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/drizzle-orm-jasonpaff-head-shakers" ~/.claude/skills/majiayu000-claude-skill-registry-drizzle-orm && rm -rf "$T"
manifest:
skills/data/drizzle-orm-jasonpaff-head-shakers/SKILL.mdsource content
Drizzle ORM Skill
Purpose
This skill enforces the project Drizzle ORM coding conventions automatically during database query development. It ensures consistent patterns for query structure, type safety, permission filtering, pagination, circuit breaker resilience, and database operations.
Activation
This skill activates when:
- Creating new query files in
src/lib/queries/ - Modifying database schema in
src/lib/db/schema/ - Writing database migrations
- Working with Drizzle query builders
- Implementing permission filtering or soft delete logic
Workflow
- Detect Drizzle ORM work (file imports from
or path containsdrizzle-orm
orqueries/
)db/schema - Load
references/Drizzle-ORM-Conventions.md - Generate/modify code following all conventions
- Scan for violations of query patterns
- Auto-fix all violations (no permission needed)
- Report fixes applied
Key Patterns
Query Classes
- Extend
class for all query classesBaseQuery - Use
for database instance and user contextQueryContext - Use
for database accessthis.getDbInstance(context) - Apply
for list queriesthis.applyPagination(options) - Use
to combine multiple SQL conditionsthis.combineFilters()
Context Types
- public read operations (isPublic = true)createPublicQueryContext()
- authenticated user operationscreateUserQueryContext(userId)
- owner-only operationscreateProtectedQueryContext(requiredUserId)
- admin access to all contentcreateAdminQueryContext(adminUserId)
Permission Filtering
- Use
for permission + soft deletethis.buildBaseFilters(isPublicCol, userIdCol, deletedAtCol, context) - Import standalone filters from
:@/lib/queries/base/permission-filters
- handles public/user/owner visibilitybuildPermissionFilter()
- handles deletedAt filtering (returnsbuildSoftDeleteFilter()
)isNull(deletedAt)
- handles owner-only accessbuildOwnershipFilter()
- combines multiple SQL conditions with ANDcombineFilters()
Resilience
- Use
for circuit breaker + retry logicthis.executeWithRetry(operation, operationName) - Use
when you need retry metadatathis.executeWithRetryDetails(operation, operationName)
Return Values
- Single item:
(returnT | null
for not found)null - List:
(returnArray<T>
for empty)[] - Count:
(returnnumber
for none)0 - Boolean check:
(returnboolean
for not found)false - Map:
(returnMap<K, V>
for empty)new Map()
Anti-Patterns to Avoid
- Never access
directly - Always usedbthis.getDbInstance(context) - Never skip permission filters - Always use
for user-visible databuildBaseFilters - Never return undefined - Return
for missing single itemsnull - Never use raw strings in queries - Use parameterized queries via Drizzle
- Never skip pagination limits - Always apply
applyPagination - Never hard delete - Use soft delete with
timestamp columndeletedAt - Never ignore circuit breaker - Use
for external callsexecuteWithRetry
References
- Complete Drizzle ORM conventionsreferences/Drizzle-ORM-Conventions.md