A simple, framework agnostic, MySQL non-reversible migrations library that accepts a pre-configured PDO connection (allowing you to preset desired connection configuration such as sql_mode or timezone and your own error handling).
Why? I looked at other libraries for migrations but they all had a large number of issues around MySQL language support and reversals, or controlling the mysql connection (eg. timezone, sql_mode) is problematic because they control creation of the connection. While I could try to enforce not using the problematic features, it's much easier if they aren't available in the first place.
Use version 1 for compatibility with PHP 5.6. Version 2+ require PHP 7.1+
Via Composer
$ composer require allenjb/migrationmanager
$pdo = new \PDO(...);
$pathToMigrations = "../db/migrations/";
$migrationsTable = 'migrations';
$manager = new AllenJB\MigrationManager($pdo, $pathToMigrations, $migrationsTable);
// List migrations
print_r ($manager->executedMigrations());
print_r ($manager->migrationsToExecute());
print_r ($manager->futureMigrations());
// Perform pending migrations
$manager->executeMigrations();
// You MUST call when you've finished using the manager to release all locks
$manager->unlock();
Filenames MUST be in the format YYYYMMDD_HHmm_ClassName.php
Time is in 24 hour format.
ClassName must be unique.
If the date is greater than today (disregarding time), then the migration will not be executed until that date. This allows you to schedule migrations in the future (for example, you're removing a field but want to leave it in the database for a period to guard against dataloss / code rollbacks).
<?php
declare(strict_types = 1);
// example filename: 20170330_1100_Initialize.php
use AllenJB\MigrationManager\AbstractMigration;
class Initialize extends AbstractMigration
{
public function up() : void
{
// Execute your changes here, using $this->db to access the PDO connection
}
}
The MIT License (MIT). Please see License File for more information.