A type-safe database migration tool for SQLite. Manage your database schema changes with timestamped migrations through a CLI or API interface.
- ✨ Simple CLI interface for managing migrations
- 🔄 Bidirectional migrations (up/down)
- 📁 File-based migrations with timestamps
- 🔍 Dry-run mode for validating changes
- 📊 Migration status tracking
- 🔒 Type-safe TypeScript implementation
npm install @ryanflorence/migralite
The CLI provides several commands for managing your database migrations:
migralite create -n "add users table"
This creates a new migration directory with two files:
+.sql
: The up migration (apply changes)-.sql
: The down migration (rollback changes)
Apply all pending migrations:
migralite up
Apply migrations up to a specific one:
migralite up 20240329123000
Rollback the most recent migration:
migralite rollback
Rollback multiple migrations:
migralite rollback --steps 3
migralite status
MIGRATIONS_DIR
: Directory for migration files (default:./db/migrations
)DB_PATH
: Path to SQLite database file (default:./db/database.db
)
The migration tool can also be used programmatically in your Node.js applications.
import { Migrator } from "@ryanflorence/migralite";
import Database from "better-sqlite3";
let db = new Database("path/to/database.db");
let migrator = new Migrator(db, "path/to/migrations");
// Apply all pending migrations
await migrator.up();
// Rollback last migration
await migrator.rollback();
class Migrator {
constructor(db: Database, dir: string, options?: { dry: boolean });
}
Creates a new migration.
let result = await migrator.create(
"add-users-table",
"CREATE TABLE users (...)",
"DROP TABLE users",
);
// Returns: { name: string, up: string, down: string }
Applies pending migrations.
// Apply all pending migrations
let applied = await migrator.up();
// Apply up to specific migration
let applied = await migrator.up("20240329123000");
// Returns: string[] (applied migration files)
Rolls back applied migrations.
// Rollback last migration
let rolledBack = await migrator.rollback();
// Rollback multiple migrations
let rolledBack = await migrator.rollback(3);
// Returns: string[] (rolled back migration files)
Gets list of pending migrations.
let pending = await migrator.getPendingMigrations();
// Returns: string[]
Gets list of applied migrations.
let applied = await migrator.getAppliedMigrations();
// Returns: MigrationEntry[]
type MigrationEntry = {
id: string;
name: string;
applied_at: string;
};
type MigratorOptions = {
dry: boolean;
};
Each migration is stored in a timestamped directory:
migrations/
└─ 20240329123000-add-users/
├─ +.sql # Up migration
└─ -.sql # Down migration
Contributions are welcome! Please feel free to submit a Pull Request.
MIT