Simple, reversible migrations for Laravel.
This package makes it easy to create automatically reversible database migrations for common operations.
This way, you don't have to deal with the time-consuming and error-prone (not to mention stupid and boring) task of manually writing the down
logic for your migrations.
Run composer require franzl/laravel-easy-migrations
and you're good to go.
Please note that - just like with Laravel - you will need to install the doctrine/dbal
package if you want to rename columns and/or drop SQLite columns.
To create a reversible migration, extend your migration class from the Franzl\EasyMigrations\EasyMigration
base class.
Your task: Overwrite the change
method, which needs to return another migration instance.
Luckily, this package already provides implementations for the most common migration operations.
For example, to add a new users
table:
use Franzl\EasyMigrations\Easy;
use Franzl\EasyMigrations\EasyMigration;
use Illuminate\Database\Schema\Blueprint;
class CreateUsersTable extends EasyMigration
{
public function change()
{
return Easy::createTable('users', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
});
}
}
Based on the parameters passed to Easy::createTable()
, this method will return a migration instance with the up
and down
methods already implemented for you.
This package currently implements the following four operations:
- Creating tables
- Renaming tables
- Dropping tables
- Renaming columns
- Adding columns
- Dropping columns
More will likely be implemented soon. Feel free to suggest a new operation type by creating an issue.
public function change()
{
return Easy::createTable('users', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
});
}
public function change()
{
return Easy::renameTable('old_users', 'new_users');
}
public function change()
{
return Easy::dropTable('users', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
});
}
Note that, for the migration to be reversible, you will need to pass in a blueprint to restore the table completely. This would be executed when the migration is rolled back.
public function change()
{
return Easy::renameColumn('users', 'name', 'username');
}
public function change()
{
return Easy::addColumns('users', [
'password' => ['string'],
'registered_at' => ['dateTime', 'nullable' => true]
]);
}
The second parameter is an array of column definitions, with the key being the column name.
The value of each item is an array with the column definitions, as understood by Laravel's Illuminate\Database\Schema\Blueprint::addColumn()
method.
The first option is the column type, any other keyed option is passed through to addColumn
.
The following options are supported for all column types:
-
nullable
: Whether the column allowsNULL
values, boolean, defaults tofalse
-
default
: Column default value, mixed -
unique
: Creates a UNIQUE index for the column, boolean, defaults tofalse
-
first
: Insert the column as the first in the table, boolean, defaults tofalse
, MySQL only -
after
: Insert the column directly after the specified existing column, string, MySQL only
In the following, all supported types, along with custom options, are listed:
-
length
: Column size, integer
No special options
-
autoIncrement
: Set totrue
to mark this column as sequence -
unsigned
: Set totrue
to mark this column as unsigned integer
-
total
: Number of decimal digits, integer, defaults to8
-
places
: Number of digits after the decimal point, integer, defaults to2
-
total
: Number of decimal digits, integer -
places
: Number of digits after the decimal point, integer
No special options
-
allowed
: An array of possible values that the column can have
No special options
No special options
No special options
No special options
public function change()
{
return Easy::dropColumns('users', [
'password' => ['string'],
'registered_at' => ['dateTime', 'nullable' => true]
]);
}
Again, just like when dropping tables, you should specify the full column definitions so that the migration can be rolled back cleanly.
For a reference of column types and their respective options, please take a look at the documentation for adding columns.