mreycode/laravel-db-migrator

A production-grade Laravel package for complex, large-scale database migrations with resumable, monitored, and batch-aware processing.

Maintainers

Package info

github.com/jonreygalera/mreycode-laravel-db-migrator

Issues

pkg:composer/mreycode/laravel-db-migrator

Statistics

Installs: 51

Dependents: 0

Suggesters: 0

Stars: 0

v2.1.1 2026-02-18 08:01 UTC

This package is auto-updated.

Last update: 2026-03-18 08:16:22 UTC


README

Mreycode Logo

Latest Version on Packagist Total Downloads PHP Version

Laravel Db Migrator

A production-grade Laravel package for complex, large-scale database migrations with resumable, monitored, and batch-aware processing.

Documentation

For full documentation, please visit Mreycode Docs - Laravel Db Migrator.

Introduction

Laravel Db Migrator transforms the often-chaotic process of data ETL (Extract, Transform, Load) into a manageable, monitored, and resumable workflow. Unlike standard schema migrations, this package is designed specifically for high-volume data movement between connections.

Installation

You can install the package via composer:

composer require mreycode/laravel-db-migrator

You should publish the configuration and system migrations using:

php artisan vendor:publish --tag=db-migrator-config
php artisan vendor:publish --tag=db-migrator-migrations
php artisan migrate

Quick Start

Generate a new migrator class:

php artisan make:db-migrator UserMigrator

Implement your migration logic:

namespace App\DbMigrators;

use Mreycode\DbMigrator\AbstractDbMigrator;
use App\Models\User;

class UserMigrator extends AbstractDbMigrator
{
    /** @var string The column name representing the unique ID in the source data */
    public $migratorSourceId = 'source_id';

    /** @var string The column name representing the unique ID in the target table */
    public $migratorTargetId = 'id';

    /** @var bool Set to true to store the source-to-target ID mapping in the history table */
    public bool $recordMigratorHistory = false;

    public function sourceData()
    {
        return $this->getSourceConnection()
            ->table('legacy_users')
            ->offset($this->getOptions()['offset'])
            ->limit($this->getOptions()['limit'])
            ->get();
    }

    public function handle($params = null)
    {
        foreach ($params['sourceData'] as $row) {
            User::create([
                'name'  => $row->full_name,
                'email' => $row->email,
            ]);
        }
    }
}

Run your migration via the interactive dashboard:

php artisan mreycode:db-migrate -i

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security-related issues, please email jonreygalera@gmail.com instead of using the issue tracker.

License

The MIT License (MIT). Please see License File for more information.