Bidirectional ORM schema converter — convert between SQL DDL, Prisma, Drizzle, TypeORM, Django, SQLAlchemy, Alembic migrations, JSON Schema, GraphQL SDL, EF Core (C#), and Scala case classes. 11 formats, 110 direction pairs.
⭐ Star this repo if you work with multiple ORMs — it helps other developers find SchemaForge!
Why SchemaForge? Every major ORM migration is a one-way street. Prisma introspects SQL but can't export back. Drizzle users manually rewrite schemas when switching ORMs. TypeORM developers are locked into decorator syntax. SchemaForge is the first tool to do bidirectional, lossless conversion between 11 schema formats — with a shared internal representation that guarantees roundtrip fidelity.
Convert any schema to any format, verify equivalence with the diff command, generate Alembic migrations, produce JSON Schema definitions, create GraphQL SDL types, convert Entity Framework (C#) entities, generate Scala case classes, and batch-process entire directories. Whether you're migrating from Prisma to Drizzle, sharing a schema with a Django backend, exposing your data model as GraphQL, translating C# entities to Scala, or working with the SchemaForge VS Code extension for live preview — SchemaForge handles it.
# Install
pip install schemaforge
# Convert Prisma → Drizzle
schemaforge convert --from prisma --to drizzle --input schema.prisma
# Generate GraphQL from SQL
schemaforge convert --from sql --to graphql --input schema.sql --output schema.graphql
# Generate JSON Schema from Prisma
schemaforge convert --from prisma --to json_schema --input schema.prisma --output schema.json
# Generate Alembic migration from SQL
schemaforge convert --from sql --to alembic --input schema.sql --output migrations/initial.py
# Apply custom type mappings
schemaforge convert --from sql --to prisma --input schema.sql --type-map my-types.yaml
# Diff two schemas
schemaforge diff schema-v1.prisma schema-v2.prisma
# Batch convert all schemas in a directory
schemaforge convert --from sql --to prisma --dir ./schemas/# PyPI (recommended)
pip install schemaforge
# Latest from source
pip install git+https://github.com/Coding-Dev-Tools/schemaforge.gitRequires Python 3.10+.
Convert a schema from one format to another. All 9 formats support conversion to and from every other format (72 direction pairs).
# Format-specific examples
schemaforge convert --from sql --to prisma --input schema.sql
schemaforge convert --from prisma --to drizzle --input schema.prisma
schemaforge convert --from drizzle --to sql --input schema.drizzle.ts
schemaforge convert --from typeorm --to django --input entities/
schemaforge convert --from django --to sqlalchemy --input models.py
schemaforge convert --from sqlalchemy --to prisma --input models.py
# Alembic migration generation
schemaforge convert --from sql --to alembic --input schema.sql --output migrations/initial.py
schemaforge convert --from prisma --to alembic --input schema.prisma --output migrations/
# JSON Schema
schemaforge convert --from sql --to json_schema --input schema.sql --output schema.json
schemaforge convert --from json_schema --to prisma --input schema.json
# GraphQL SDL
schemaforge convert --from sql --to graphql --input schema.sql --output schema.graphql
schemaforge convert --from graphql --to prisma --input schema.graphql
# Custom type mapping
schemaforge convert --from sql --to prisma --input schema.sql --type-map my-types.yaml
# Dir mode (batch convert all files)
schemaforge convert --from sql --to prisma --dir ./schemas/Compare two schema files in the same format and see line-level differences.
schemaforge diff schema-v1.prisma schema-v2.prisma
schemaforge diff schema.sql schema-updated.sql --format sql
schemaforge diff fixtures/sample.sql fixtures/sample.prisma --format prismaDetects added, removed, and modified tables, columns, indexes, and constraints.
| Format | Import | Export | Roundtrip |
|---|---|---|---|
| SQL DDL | ✓ | ✓ | ✓ |
| Prisma schema | ✓ | ✓ | ✓ |
| Drizzle schema | ✓ | ✓ | ✓ |
| TypeORM entities | ✓ | ✓ | ✓ |
| Django models | ✓ | ✓ | ✓ |
| SQLAlchemy models | ✓ | ✓ | ✓ |
| Alembic migrations | — | ✓ | — |
| JSON Schema | ✓ | ✓ | ✓ |
| GraphQL SDL | ✓ | ✓ | ✓ |
| EF Core (C#) | ✓ | ✓ | ✓ |
| Scala case class | ✓ | ✓ | ✓ |
Alembic is generator-only: you can create migration scripts from any format, but parsing existing migrations back to IR is not yet supported.
| CLI identifier | Format |
|---|---|
sql |
SQL DDL |
prisma |
Prisma schema |
drizzle |
Drizzle ORM schema |
typeorm |
TypeORM entities |
django |
Django models |
sqlalchemy |
SQLAlchemy declarative models |
alembic |
Alembic migration scripts |
json_schema |
JSON Schema (draft 2020-12) |
graphql |
GraphQL SDL |
ef |
Entity Framework Core (C#) |
scala |
Scala case classes (Doobie/Quill/Slick) |
SchemaForge uses a shared Internal Representation (IR) — all formats convert to and from this common schema definition. This architecture guarantees:
- Zero-loss roundtripping:
sql → prisma → sqlproduces the same schema you started with - Bidirectional conversion: every supported format can convert to every other format
- Extensibility: adding a new format requires only a parser and a generator — no pairwise converters
| SQL DDL ───┐
| Prisma ────┤
| Drizzle ───┤
| TypeORM ───┤
| Django ────┤
| SQLAlchemy ───┤
| Alembic ────┤
| JSON Schema ──┤
| GraphQL ────┤
| EF Core ─────┤
| Scala ─────┤
Each parser reads format-specific syntax and builds a schema IR. Each generator takes the same IR and produces format-native output. The fn: prefix convention preserves SQL function defaults (CURRENT_TIMESTAMP, NOW(), gen_random_uuid()) across format boundaries.
Override default type mappings with YAML or JSON configuration files.
# type-overrides.yaml
overrides:
prisma:
STRING: "String @db.VarChar({length})"
UUID: "String @db.Uuid"
sql:
STRING: "TEXT"
DATETIME: "TIMESTAMP WITH TIME ZONE"Template variables available: {length}, {precision}, {scale}, {values}.
# Apply overrides during conversion
schemaforge convert --from sql --to prisma --input schema.sql --type-map type-overrides.yamlSchemaForge maps types intelligently between ORM systems. The core ColumnType enum represents all supported data types, and each format maps them to their native equivalents.
| ColumnType | SQL DDL | Prisma | Drizzle | TypeORM | Django | SQLAlchemy | Alembic | JSON Schema | GraphQL |
|---|---|---|---|---|---|---|---|---|---|
| STRING | VARCHAR(n) / TEXT | String @db.VarChar(n) | varchar(n) | varchar | CharField(max_length=n) | String(n) | sa.String(n) | type: string | String |
| INTEGER | INTEGER | Int | integer | integer | IntegerField | Integer | sa.Integer | type: integer | Int |
| FLOAT | FLOAT | Float | real | float | FloatField | Float | sa.Float | type: number | Float |
| BOOLEAN | BOOLEAN | Boolean | boolean | boolean | BooleanField | Boolean | sa.Boolean | type: boolean | Boolean |
| DATETIME | TIMESTAMP | DateTime | timestamp | timestamp | DateTimeField | DateTime | sa.DateTime | format: date-time | DateTime |
| DATE | DATE | DateTime | date | date | DateField | Date | sa.Date | format: date | Date |
| TIME | TIME | DateTime | time | time | TimeField | Time | sa.Time | format: time | Time |
| TEXT | TEXT | String | text | text | TextField | Text | sa.Text | type: string | String |
| BLOB | BLOB | Bytes | blob | blob | BinaryField | LargeBinary | sa.LargeBinary | format: binary | String |
| JSON | JSON | Json | json | json | JSONField | JSON | sa.JSON | type: object | JSON |
| UUID | UUID | String | uuid | uuid | UUIDField | Uuid | sa.Uuid | format: uuid | ID |
| ENUM | ENUM('a','b') | (via enum) | pgEnum | enum | CharField | Enum | sa.Enum | (enum) | enum |
| DECIMAL | DECIMAL(p,s) | Decimal | numeric(p,s) | decimal(p,s) | DecimalField | Numeric(p,s) | sa.Numeric(p,s) | type: number | Float |
| CUSTOM | (passthrough) | (passthrough) | (passthrough) | (passthrough) | (passthrough) | (passthrough) | (passthrough) | (passthrough) | (passthrough) |
Function defaults (CURRENT_TIMESTAMP, NOW(), gen_random_uuid(), etc.) are preserved across conversions using a fn: prefix convention.
Try SchemaForge immediately with our example blog schema. The fixtures/ directory contains an equivalent schema (users, posts, categories with enums and various data types) in all 9 formats:
# List all fixtures
ls fixtures/
# Convert SQL → Prisma
schemaforge convert --from sql --to prisma --input fixtures/sample.sql
# Convert Prisma → Django
schemaforge convert --from prisma --to django --input fixtures/sample.prisma
# Convert SQL → GraphQL
schemaforge convert --from sql --to graphql --input fixtures/sample.sql
# Convert SQL → JSON Schema
schemaforge convert --from sql --to json_schema --input fixtures/sample.sql
# Convert Prisma → Alembic migration
schemaforge convert --from prisma --to alembic --input fixtures/sample.prisma --output migrations/
# Custom type mapping demo
schemaforge convert --from sql --to prisma --input fixtures/sample.sql \
--type-map fixtures/sample-type-overrides.yaml
# Batch convert all fixtures from SQL
schemaforge convert --from sql --to prisma --dir fixtures/
# Diff two format outputs
schemaforge diff fixtures/sample.sql fixtures/sample.prisma --format prismaEach fixture demonstrates the same blog schema so you can compare ORM syntax side-by-side and verify roundtrip consistency.
- Bidirectional conversion — all 11 formats convert to and from every other format
- Zero-loss roundtripping —
sql → prisma → sqlreproduces the original schema exactly - Custom type mappings — YAML/JSON config files to override any type mapping with template variables
- VS Code extension — live preview, schema diff, and one-click conversion from VS Code
- Alembic migration generation — create database migration scripts from any schema format
- JSON Schema — import/export schema definitions as JSON Schema (draft 2020-12)
- GraphQL SDL — generate or consume GraphQL type definitions with enums, directives, and scalars
- EF Core (C#) support — import/export Entity Framework entity classes with data annotations
- Scala case class support — generate case classes targeting Doobie/Quill/Slick
- Diff mode — compare two schemas in the same format with line-level differences
- Batch mode — convert entire directories of schema files with one command
- Intelligent type mapping — types map correctly across all 11 formats
- Function default preservation —
CURRENT_TIMESTAMP,NOW(),gen_random_uuid()survive roundtrips - MySQL support — ENGINE=InnoDB, AUTO_INCREMENT, DEFAULT CHARSET, COMMENT table options
- Inline ENUM —
ENUM('small', 'medium', 'large')column types parsed and roundtripped - Relation preservation — indexes, unique constraints maintained across all conversions
- Custom type handling — dialect-specific types (JSONB, etc.) pass through via CUSTOM type
SchemaForge includes an MCP (Model Context Protocol) server that exposes all schema operations as tools for AI agents. This allows AI coding assistants like Claude Code, Cursor, and others to convert, diff, and check schemas directly.
# Install with MCP support
pip install schemaforge[mcp]
# Start the server (stdio mode — default for AI clients)
schemaforge mcp
# Start as SSE HTTP server
schemaforge mcp --sse --port 8000| Tool | Description |
|---|---|
convert |
Convert a schema between any two of the 11 formats |
diff |
Compare two schemas and show differences |
check |
Verify schema consistency across a directory |
formats |
List all supported formats with descriptions |
detect_format |
Identify format from filename |
Claude Desktop (claude_desktop_config.json):
{
"mcpServers": {
"schemaforge": {
"command": "schemaforge",
"args": ["mcp"]
}
}
}Cursor: Add to .cursor/mcp.json:
{
"mcpServers": {
"schemaforge": {
"command": "schemaforge",
"args": ["mcp"]
}
}
}The SchemaForge VS Code extension provides live schema preview, quick conversion, and schema diffing directly from your editor.
- Live Preview — opens a side panel showing your active schema file converted to all other formats (tabbed interface for quick comparison)
- Quick Convert —
Ctrl+Alt+S/Cmd+Alt+Sto convert the active editor's schema to your configured default target format - Format Detection —
Ctrl+Alt+D/Cmd+Alt+Dto detect and display the format of the active schema file - Diff Two Schemas — select two schema files to diff them side-by-side in VS Code's native diff editor
- Right-Click Conversion — right-click any schema file in the explorer to convert it
- Custom Editor — open
.schemaforgefiles for a rich conversion preview - Auto-Refresh — preview panel updates when you save a schema file or switch tabs
- Install SchemaForge:
pip install schemaforge - Install the extension from the VS Code Marketplace
- Open a
.sql,.prisma,.graphql,.cs, or.scalafile - Run
SchemaForge: Show Previewfrom the command palette
| Setting | Default | Description |
|---|---|---|
schemaforge.cliPath |
schemaforge |
Path to the schemaforge CLI executable |
schemaforge.defaultTargetFormat |
prisma |
Default target format for quick conversions |
schemaforge.livePreview.enabled |
true |
Enable live preview panel when editing schema files |
git clone https://github.com/Coding-Dev-Tools/vscode-schemaforge.git
cd vscode-schemaforge
npm install
npm run compile
# Press F5 in VS Code to launch extension host| Version | Features |
|---|---|
| v0.1.0 | SQL DDL ↔ Prisma bidirectional conversion |
| v0.2.0 | Drizzle schema support |
| v0.3.0 | TypeORM entities support |
| v0.4.0 | Django models support |
| v0.5.0 | SQLAlchemy support, diff mode, batch mode, custom type mappings |
| v0.6.0 | SQL parser edge cases (TEMPORARY TABLE, backtick quoting, fn: defaults) |
| v0.7.0 | MySQL table options (ENGINE, CHARSET), inline ENUM('a','b','c') |
| v0.8.0 | Alembic migration generation (7th format) |
| v0.9.0 | Shared generator base module, refactored fn: default handling |
| v1.0.0 | Stable release — comprehensive docs, CLI polish |
| v1.1.0 | Custom type mapping configuration (YAML/JSON overrides) |
| v1.2.0 | JSON Schema support (8th format) |
| v1.3.0 | GraphQL SDL support (9th format) |
| v1.4.0 | Schema consistency check, CI/CD workflow, MCP server |
| v1.5.0 | Entity Framework Core (C#) support (10th format) |
| v1.6.0 | Scala case class support (11th format) |
| v1.7.0 | VS Code extension — live preview, diff, quick convert |
- VS Code extension: in-editor syntax highlighting for all 11 schema formats
- Live schema watch mode for automatic re-conversion on file change
- Mermaid/ERD diagram generation from schema IR
- Terraform/OpenTofu provider for schema drift detection
- Web dashboard with schema diff history
SchemaForge is one of eight tools in the Revenue Holdings suite. One license covers all CLI tools.
| Plan | Price | Best For |
|---|---|---|
| Free | $0 | Individual devs, OSS — CLI only, rate-limited |
| SchemaForge Individual | $15/mo ($12 billed annually) | Professional devs — unlimited conversions, batch mode |
| Suite (all 8 tools) | $49/mo ($39 billed annually) | Full Revenue Holdings toolkit — 40% savings |
| Team | $79/mo ($63 billed annually) | Up to 5 devs — shared schemas, team dashboard, alerts |
| Enterprise | Custom | SSO, RBAC, compliance reports, dedicated support |
🔹 No lock-in: CLI works fully offline on the free tier — no telemetry, no phone-home. 🔹 Annual billing: Save 20%.
| Feature | Free | Individual | Suite | Team | Enterprise |
|---|---|---|---|---|---|
| CLI: convert, diff | ✓ | ✓ | ✓ | ✓ | ✓ |
| All 9 format directions | — | ✓ | ✓ | ✓ | ✓ |
| Alembic migration generation | — | ✓ | ✓ | ✓ | ✓ |
| JSON Schema import/export | — | ✓ | ✓ | ✓ | ✓ |
| GraphQL SDL import/export | — | ✓ | ✓ | ✓ | ✓ |
| MCP server (AI agent tools) | ✓ | ✓ | ✓ | ✓ | ✓ |
| Custom type mappings | — | ✓ | ✓ | ✓ | ✓ |
| Batch directory conversion | — | ✓ | ✓ | ✓ | ✓ |
| Team shared type mappings | — | — | — | ✓ | ✓ |
| Dashboard & analytics | — | — | — | ✓ | ✓ |
| Compliance reports | — | — | — | — | ✓ |
| RBAC / SSO / SAML / OIDC | — | — | — | — | ✓ |
| Priority support | Community | 24h | 24h | 8h | Dedicated |
# Clone and install in dev mode
git clone https://github.com/Coding-Dev-Tools/schemaforge.git
cd schemaforge
pip install -e ".[dev]"
# Run tests
pytest tests/ -v
# Run tests with coverage
pytest tests/ --cov=schemaforgePRs welcome! New format parsers/generators, bug fixes, and documentation improvements are all appreciated.
- Fork the repo
- Create a feature branch (
git checkout -b feat/awesome-format) - Add your parser and generator in
src/schemaforge/parsers/andsrc/schemaforge/generators/ - Register in
src/schemaforge/convert.py - Add tests in
tests/ - Run the full test suite (
pytest tests/ -v) - Submit a PR
MIT — see LICENSE
Part of Revenue Holdings — a suite of 10 developer CLI tools built by autonomous AI agents. Also check out the SchemaForge VS Code extension, API Contract Guardian (breaking change detection), DeployDiff (infrastructure diffs), json2sql (JSON → SQL), ConfigDrift (config drift detection), DeadCode (dead code cleanup), APIAuth (API key management), APIGhost (mock API server), Envault (env sync), and click-to-mcp (CLI → MCP server).