console-helpers/db-migration

Database migrations made simple

Maintainers

👁 aik099

Package info

github.com/console-helpers/db-migration

pkg:composer/console-helpers/db-migration

Statistics

Installs: 4 342

Dependents: 1

Suggesters: 0

Stars: 1

Open Issues: 2

v0.2.0 2024-12-13 22:11 UTC

Requires

  • php: >=5.6
  • aura/sql: ^2.5 || ^3.0 || ^4.0 || ^5.0

Suggests

None

Provides

None

Conflicts

None

Replaces

None

BSD-3-Clause 48d4680c8ec81d4a701821689dd842bb37a3ec5f

  • Alexander Obuhovich <aik.bold.woop@gmail.com>

databasesqlitemigration

This package is auto-updated.

Last update: 2026-06-18 17:57:23 UTC


README

👁 CI
👁 codecov
👁 Scrutinizer Code Quality

👁 Latest Stable Version
👁 Total Downloads
👁 License

DB-Migration is a library allows to run migrations on SQLite databases with ease.

Goals, when developing the library:

  • allow initializing library without knowing database connection details upfront
  • allow creating new migration file without knowing database connection details upfront
  • allow using several databases in parallel
  • being framework agnostic

Usage

Initialization

use ConsoleHelpers\DatabaseMigration\MigrationManager;
use ConsoleHelpers\DatabaseMigration\PhpMigrationRunner;
use ConsoleHelpers\DatabaseMigration\SqlMigrationRunner;
use Pimple\Container;

// 1. Create migration manager instance.
$migration_manager = new MigrationManager(
	'/path/to/migrations', // Directory containing migrations.
	new Container() // Anything implementing "ArrayAccess".
);

// 2. Register migration runners.
$migration_manager->registerMigrationRunner(new SqlMigrationRunner());
$migration_manager->registerMigrationRunner(new PhpMigrationRunner());

Creating new migration

The following code will create YYYYMMDD_HHMM_name.ext migration file in configured migration folder and return it's name.

use ConsoleHelpers\DatabaseMigration\MigrationManager;

$migration_name = $migration_manager->createMigration(
	'example_migration', // any valid filename
	'sql' // 'php' or 'sql' (comes from migration runner)
);

As a result:

  • the /path/to/migrations/20160519_2155_example_migration.sql file would be created
  • the 20160519_2155_example_migration.sql would be returned to $migration_name variable

Migration Templates

SQL:

Empty file.

PHP:

<?php
use ConsoleHelpers\DatabaseMigration\MigrationContext;

return function (MigrationContext $context) {
	// Write PHP code here.
};

Running migrations

use Aura\Sql\ExtendedPdo;
use ConsoleHelpers\DatabaseMigration\MigrationManager;
use ConsoleHelpers\DatabaseMigration\MigrationContext;
use Pimple\Container;

// 1. Create database connection.
$database = new ExtendedPdo('sqlite:/path/to/database.sqlite');

// 2. Run migrations.
$migration_manager->runMigrations(
	// Context consists of the database and container.
	new MigrationContext($database)
);

Installation

Execute this command to add dependencies:

php composer.phar require console-helpers/db-migration:^0.1

Requirements

Contributing

See CONTRIBUTING file.

License

DB-Migration is released under the BSD-3-Clause License. See the bundled LICENSE file for details.