Files
dbtype/README.md
glm-5.1 03a00e2f04 Rename @alkdev/drizzlebox -> @alkdev/dbtype
Update package name, description, repo URL, keywords, and docs
to reflect the new project identity as dbtype.
2026-05-22 09:28:01 +00:00

74 lines
2.1 KiB
Markdown

# @alkdev/dbtype
Schema-first multi-dialect TypeBox/Drizzle bridge — define once, validate and deploy anywhere.
Based on [drizzle-typebox](https://github.com/drizzle-team/drizzle-orm/tree/main/drizzle-typebox) by the Drizzle Team, adapted for use with `@alkdev/typebox` (a maintained fork of `@sinclair/typebox`).
## Install
```bash
npm install @alkdev/dbtype
npm install @alkdev/typebox
npm install drizzle-orm
```
## Features
- Create select schemas for tables, views, and enums
- Create insert and update schemas for tables
- Supports all dialects: PostgreSQL, MySQL, and SQLite
- Custom TypeBox instance support via `createSchemaFactory`
## Usage
```ts
import { pgEnum, pgTable, serial, text, timestamp } from 'drizzle-orm/pg-core';
import { createInsertSchema, createSelectSchema, createUpdateSchema } from '@alkdev/dbtype';
import { Type } from '@alkdev/typebox';
import { Value } from '@alkdev/typebox/value';
const users = pgTable('users', {
id: serial('id').primaryKey(),
name: text('name').notNull(),
email: text('email').notNull(),
role: text('role', { enum: ['admin', 'user'] }).notNull(),
createdAt: timestamp('created_at').notNull().defaultNow(),
});
// Schema for inserting a user
const insertUserSchema = createInsertSchema(users);
// Schema for updating a user
const updateUserSchema = createUpdateSchema(users);
// Schema for selecting a user
const selectUserSchema = createSelectSchema(users);
// Overriding fields
const insertUserSchema = createInsertSchema(users, {
role: Type.String(),
});
// Refining fields
const insertUserSchema = createInsertSchema(users, {
id: (schema) => Type.Number({ ...schema, minimum: 0 }),
role: Type.String(),
});
// Validation
const isUserValid: boolean = Value.Check(insertUserSchema, {
name: 'John Doe',
email: 'johndoe@test.com',
role: 'admin',
});
```
## Differences from drizzle-typebox
- Uses `@alkdev/typebox` instead of `@sinclair/typebox`
- Standalone package (no monorepo dependency)
- Published as `@alkdev/dbtype` on npm
## Attribution
Based on [drizzle-typebox](https://github.com/drizzle-team/drizzle-orm/tree/main/drizzle-typebox) by the Drizzle Team, licensed under Apache-2.0.