migrations/Version20250624151014.php line 1

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace DoctrineMigrations;
  4. use Doctrine\DBAL\Schema\Schema;
  5. use Doctrine\Migrations\AbstractMigration;
  6. final class Version20250624151014 extends AbstractMigration
  7. {
  8.     public function getDescription(): string
  9.     {
  10.         return 'Add fields Product.{pack, productPack}, added entity {ProductPack}';
  11.     }
  12.     public function up(Schema $schema): void
  13.     {
  14.         $this->addSql('CREATE TABLE product_pack (id INT AUTO_INCREMENT NOT NULL, product_id INT NOT NULL, product_related_id INT NOT NULL, quantity INT NOT NULL, INDEX IDX_1A367C824584665A (product_id), INDEX IDX_1A367C82D2059F2A (product_related_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
  15.         $this->addSql('ALTER TABLE product_pack ADD CONSTRAINT FK_1A367C824584665A FOREIGN KEY (product_id) REFERENCES product (id)');
  16.         $this->addSql('ALTER TABLE product_pack ADD CONSTRAINT FK_1A367C82D2059F2A FOREIGN KEY (product_related_id) REFERENCES product (id)');
  17.         $this->addSql('ALTER TABLE product ADD pack TINYINT(1) DEFAULT 0 NOT NULL');
  18.     }
  19.     public function down(Schema $schema): void
  20.     {
  21.         $this->addSql('ALTER TABLE product_pack DROP FOREIGN KEY FK_1A367C824584665A');
  22.         $this->addSql('ALTER TABLE product_pack DROP FOREIGN KEY FK_1A367C82D2059F2A');
  23.         $this->addSql('DROP TABLE product_pack');
  24.         $this->addSql('ALTER TABLE product DROP pack');
  25.     }
  26. }