To use migrations, install yiisoft/db-migration package:
composer require yiisoft/db-migration
First, configure DI container. Create config/common/db.php
with the following content:
<?php
declare(strict_types=1);
use Yiisoft\Db\Connection\ConnectionInterface;
use Yiisoft\Db\Sqlite\Connection as SqliteConnection;
return [
ConnectionInterface::class => [
'class' => SqliteConnection::class,
'__construct()' => [
'dsn' => 'sqlite:' . __DIR__ . '/Data/yiitest.sq3'
]
]
];
Add the following to config/params.php
:
...
'yiisoft/db-migration' => [
'newMigrationNamespace' => 'App\\Migration',
'sourceNamespaces' => ['App\\Migration'],
],
...
Now test if it works:
./yii list migrate
To work with migrations, you can use the provided view.
./yii migrate:create my_first_table --command=table --fields=name,example --table-comment=my_first_table
That would generate the following:
<?php
declare(strict_types=1);
namespace App\Migration;
use Yiisoft\Db\Migration\MigrationBuilder;
use Yiisoft\Db\Migration\RevertibleMigrationInterface;
use Yiisoft\Db\Migration\TransactionalMigrationInterface;
/**
* Handles the creation of table `my_first_table`.
*/
final class M240115143455CreateMyFirstTableTable implements RevertibleMigrationInterface, TransactionalMigrationInterface
{
public function up(MigrationBuilder $b): void
{
$b->createTable('my_first_table', [
'id' => $b->primaryKey(),
'name',
'example',
]);
$b->addCommentOnTable('my_first_table', 'dest');
}
public function down(MigrationBuilder $b): void
{
$b->dropTable('my_first_table');
}
}
For more information see
Migrations in Yii2 and the yiisoft/db-migration package are not compatible,
and the migration
table is also not
compatible.
A probable solution is to use structure dumps and rename the old migration
table. Upon the initial execution of
migrations, a new migration
table with new fields will be created. All subsequent changes in the database schema are
applied using the new migration
component and recorded in the new migration table.