data:image/s3,"s3://crabby-images/3d01c/3d01cfa138e6c20d64be6b0d45a44d642af6db0b" alt=""
data:image/s3,"s3://crabby-images/8d2f0/8d2f033fd81a7c9b4c0db7064c5e701fe4a15dde" alt=""
data:image/s3,"s3://crabby-images/4c53c/4c53cfe79befc0e387ccca330933f0a09eeee889" alt=""
data:image/s3,"s3://crabby-images/fac0b/fac0ba7ebdfa6b7d38afdd3edf6025ea31bd70f3" alt=""
data:image/s3,"s3://crabby-images/c0e63/c0e6363e16f457e0e586dded12944ab512d53c74" alt=""
data:image/s3,"s3://crabby-images/f1ee1/f1ee1e837d718035b68773a5cc0f291e1e7dc01b" alt=""
data:image/s3,"s3://crabby-images/8f549/8f5498af8be56d5d435d37f1a68e0426cdae4a88" alt=""
data:image/s3,"s3://crabby-images/dc5ff/dc5ffca19cc83324f7c546eeb4f4943279aa56d2" alt=""
data:image/s3,"s3://crabby-images/be1d2/be1d2b8fe7c10fe8387b9e418c8daf0d65dd3f27" alt=""
data:image/s3,"s3://crabby-images/9b0fb/9b0fb83954735cc7638327af5ca6b91b4574cbd0" alt=""
data:image/s3,"s3://crabby-images/dabdb/dabdbab6912cb73868b39ca8212fad55f2b4ecbc" alt=""
Using
migrations & fixtures
Miro Svrtan
@msvrtan
data:image/s3,"s3://crabby-images/1884d/1884d51c994fc9a3cb164f6ad214265b0d4f1d9d" alt=""
Migrations
Server migrations
data:image/s3,"s3://crabby-images/572c1/572c1ec3ccfa185726873b5479c06caa61093573" alt=""
data:image/s3,"s3://crabby-images/572c1/572c1ec3ccfa185726873b5479c06caa61093573" alt=""
Database system migrations
data:image/s3,"s3://crabby-images/d1612/d1612026ace6e907a2e9303cf5beb5c8ac79be72" alt=""
data:image/s3,"s3://crabby-images/d1612/d1612026ace6e907a2e9303cf5beb5c8ac79be72" alt=""
Schema migrations
data:image/s3,"s3://crabby-images/df053/df0531c3e4e6cf24bf2b58eb0cc81bd3e2918bfa" alt=""
data:image/s3,"s3://crabby-images/392b4/392b46ae9a4fc221a8c78ac854bc0795818a39f7" alt=""
Schema migrations
data:image/s3,"s3://crabby-images/392b4/392b46ae9a4fc221a8c78ac854bc0795818a39f7" alt=""
data:image/s3,"s3://crabby-images/c6819/c6819b407253ee47f7d7ae947c7a14f7f01d3262" alt=""
Model schema
Database schema
Create migration
Calculate differences
Create migration file
data:image/s3,"s3://crabby-images/4dd7c/4dd7ca0dfec0b95c3719d1c7afc3dc29ace827d1" alt=""
Model schema
Database schema
Source of truth!
Calculate differences
Create migration file
data:image/s3,"s3://crabby-images/4dd7c/4dd7ca0dfec0b95c3719d1c7afc3dc29ace827d1" alt=""
<?php
namespace DoctrineMigrations;
use Doctrine\DBAL\Migrations\AbstractMigration;
use Doctrine\DBAL\Schema\Schema;
class Version2 extends AbstractMigration
{
public function up(Schema $schema)
{
$this->addSql('CREATE TABLE user (id INT NOT NULL, username VARCHAR(180), ...)');
$this->addSql('CREATE UNIQUE INDEX UNIQ_957A6479C05FB297 ON user (username)');
}
...
}
Version2
Version1
Run migration
Any new migrations?
Run migration `Version2`
Version1
Mark migration `Version2` as run
Version2
Version2
Run migration (again)
Any new migrations?
Nope, I'm done
Version1
Version1
<?php
namespace DoctrineMigrations;
use Doctrine\DBAL\Migrations\AbstractMigration;
use Doctrine\DBAL\Schema\Schema;
class Version2 extends AbstractMigration
{
public function up(Schema $schema)
{
$this->addSql('CREATE TABLE user (id INT NOT NULL, username VARCHAR(180), ...)');
$this->addSql('CREATE UNIQUE INDEX UNIQ_957A6479C05FB297 ON user (username)');
}
public function down(Schema $schema)
{
$this->addSql('DROP TABLE user');
}
}
data:image/s3,"s3://crabby-images/4dd7c/4dd7ca0dfec0b95c3719d1c7afc3dc29ace827d1" alt=""
Move forward/ no rollbacks
<?php
namespace DoctrineMigrations;
use Doctrine\DBAL\Migrations\AbstractMigration;
use Doctrine\DBAL\Schema\Schema;
class Version20181027165500 extends AbstractMigration
{
public function up(Schema $schema)
{
...
}
public function down(Schema $schema)
{
..
}
}
Versioning
data:image/s3,"s3://crabby-images/4dd7c/4dd7ca0dfec0b95c3719d1c7afc3dc29ace827d1" alt=""
<?php
namespace DoctrineMigrations;
use Doctrine\DBAL\Migrations\AbstractMigration;
use Doctrine\DBAL\Schema\Schema;
class Version20181027165500 extends AbstractMigration
{
public function up(Schema $schema)
{
$this->abortIf('postgresql' !== $this->getDatabasePlatform(),
'Migration can only be executed safely on \'postgresql\'.');
$this->addSql('CREATE TABLE user (id INT NOT NULL, username VARCHAR(180), ...)');
$this->addSql('CREATE UNIQUE INDEX UNIQ_957A6479C05FB297 ON user (username)');
}
public function down(Schema $schema)
{
$this->abortIf('postgresql' !== $this->getDatabasePlatform(),
'Migration can only be executed safely on \'postgresql\'.');
$this->addSql('DROP TABLE user');
}
}
Locked to vendor
data:image/s3,"s3://crabby-images/4dd7c/4dd7ca0dfec0b95c3719d1c7afc3dc29ace827d1" alt=""
<?php
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
class CreateUserTable extends Migration
{
public function up()
{
Schema::create('users', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
...
});
}
public function down()
{
Schema::drop('users');
}
}
Laravel migrations
data:image/s3,"s3://crabby-images/569e6/569e65740ca6ea2ed87bc76213be7ad90a4acd28" alt=""
Deployment
Deploying on large datasets
Fixtures
'dummy' instead of production data
Fixtures
<?php
namespace App\DataFixtures\ORM;
use App\Entity\User;
use Doctrine\Common\DataFixtures\AbstractFixture;
use Doctrine\Common\Persistence\ObjectManager;
class UsersFixtures extends AbstractFixture
{
public function load(ObjectManager $manager)
{
$user1 = new User();
$user1->setId(1);
$user1->setUsername('username1');
$user1->setEmail('username1@example.com');
$user2 = new User();
$user2->setId(2);
$user2->setUsername('username2');
$user2->setEmail('username2@example.com');
$manager->persist($user1);
$manager->persist($user2);
$manager->flush();
}
}
<?php
namespace App\DataFixtures\ORM;
use App\Entity\User;
use Doctrine\Common\DataFixtures\AbstractFixture;
use Doctrine\Common\Persistence\ObjectManager;
class UsersFixtures extends AbstractFixture
{
public function load(ObjectManager $manager)
{
for ($i = 1; $i < 10; $i++) {
$user = new User();
$user->setId($i);
$user->setUsername('username'.$i);
$user->setEmail('username'.$i.'@example.com');
$manager->persist($user);
}
$manager->flush();
}
}
<?php
namespace App\DataFixtures\ORM;
use App\Entity\User;
use Doctrine\Common\DataFixtures\AbstractFixture;
use Doctrine\Common\Persistence\ObjectManager;
class UsersFixtures extends AbstractFixture
{
public function load(ObjectManager $manager)
{
for ($i = 1; $i < 10; $i++) {
$user = new User();
$user->setId($i);
$user->setUsername('username'.$i);
$user->setEmail('username'.$i.'@example.com');
$manager->persist($user);
}
$manager->flush();
}
}
<?php
namespace App\DataFixtures\ORM;
..
class UsersFixtures extends AbstractFixture
{
public function load(ObjectManager $manager)
{
$alex = new User();
$alex->setId(1);
$alex->setUsername('alex');
$alex->setEmail('alex@example.com');
$sasha = new User();
$sasha->setId(2);
$sasha->setUsername('sasha');
$sasha->setEmail('sasha@example.com');
$manager->persist($alex);
$manager->persist($sasha);
$manager->flush();
}
}
Proper naming!
Demo time
data:image/s3,"s3://crabby-images/fbfc8/fbfc8212e540046140ef94286a6cf3cfdba6ce34" alt=""
Thank you!
Miro Svrtan
@msvrtan
data:image/s3,"s3://crabby-images/1884d/1884d51c994fc9a3cb164f6ad214265b0d4f1d9d" alt=""
Feedback -> https://joind.in/talk/6c119
miro (at) mirosvrtan.me
data:image/s3,"s3://crabby-images/dd9b9/dd9b9f32df41ed4d0b35557bc0049b1f11ef33f0" alt=""
Any questions?
Using migrations and fixtures
By Miro Svrtan
Using migrations and fixtures
- 2,501