db-entity-migrate
is a cross database table or collection migration library that supports seamless data migration between different databases supporting both SQL and NoSQL databases.
-
Database Support: MySQL, PostgreSQL, SQLite3, OracleDB, & MongoDB.
-
Project Support: Works wit TypeScript and Javascript (ESM & CommonJs).
-
Batch Processing: Efficiently handle large datasets by migrating data in configurable batches.
-
Field Mapping: Define custom mappings for fields, including transformations and default values.
-
Validation with Zod: Validate migrated data using Zod schemas with customizable logging options.
-
User-Level Configurations: Configure migrations at both the project level and user level using TypeScript.
-
Robust Logging: Provides options writing database results and schema validations logs to disk.
-
Dry Run: Review migration and validations without writing to the database.
npm install db-entity-migrate
-
Import the migrate method.
-
Pass the configuration to the migrate method.
-
Run your migration script.
const { migrate } = require('db-entity-migrate');
const config = require('./config');
migrate(config);
// config.ts
import { Config } from 'db-entity-migrate';
import { z } from 'zod';
export const config: Config = {
// Database configurations
db: {
source: {
// Source database details
client: 'mongodb',
// Check below on how to provide connection info other databases
connection: 'mongodb://localhost:27017',
database: 'source_database',
collection: 'source_collection',
},
destination: {
// Destination database details
client: 'mysql',
connection: {
host: '127.0.0.1',
port: 3306,
user: 'your_username',
password: 'your_password',
},
database: 'destination_database',
table: 'destination_table',
createTableRawSql: `CREATE TABLE test2 (
id VARCHAR(24) NOT NULL PRIMARY KEY,
name VARCHAR(255),
age INT,
createdAt TIMESTAMP
);`,
},
},
// Migration configurations
migration: {
log: {
// Logging configurations
level: 'info',
filePath: 'migration_log.json',
},
batchSize: {
// Batch processing configurations
read: 500,
write: 500,
},
dryRun: false, // Set to true for a dry run without actual writes
},
// Field mapping configurations
fieldMapping: {
mapping: {
// Custom field mappings
_id: {
to: 'id',
transform: (o: any) => o._id.toString(),
},
name: { to: 'name' },
age: { to: 'age' },
createdAt: { to: 'createdAt' }, // Example: Snake case conversion
},
strictMapping: true, // Set to false to allow unmapped fields
idField: 'id'
},
// Validation configurations
validation: {
zodValidator: z.object({}), // Zod schema for validation (customize as needed)
zodParserType: 'safeParse', // Zod parser type (options: 'parse', 'safeParse')
logPath: 'validation_log.json', // Validation log file path
},
};
Database connection options which can be used either in source config or at destination config.
connection: {
host: '127.0.0.1',
port: 3306,
user: 'your_username',
password: 'your_password',
}
connection: 'postgresql://localhost:5432',
connection: {
filename: "./mydb.sqlite"
}
connection: {
host: 'localhost',
user: 'your_username',
password: 'your_password',
database: 'your_database_name'
}
connection: 'mongodb://localhost:27017',
Contributions are welcome! Feel free to open issues or pull requests.