Skip to content

arrayappy/db-entity-migrate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

db-entity-migrate

Overview

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.

Features

  • 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.

Installation

npm install db-entity-migrate

Usage

Project Level (JavaScript/TypeScript)

  • 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);

Configuration

Sample 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
  },
};

Detailed Documentation

Database connection options which can be used either in source config or at destination config.

MySQL

connection: {
  host: '127.0.0.1',
  port: 3306,
  user: 'your_username',
  password: 'your_password',
}

PostgreSQL

connection: 'postgresql://localhost:5432',

SQLite3

connection: {
  filename: "./mydb.sqlite"
}

OracleDB

connection: {
  host: 'localhost',
  user: 'your_username',
  password: 'your_password',
  database: 'your_database_name'
}

MongoDB

connection: 'mongodb://localhost:27017',

Contributing

Contributions are welcome! Feel free to open issues or pull requests.