<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
/**
* 商品規格にメーカー取り寄せフラグを追加するためのマイグレーション
* dtb_product_classテーブルにmaker_order_flgフィールドを追加
*/
final class Version20250918000000 extends AbstractMigration
{
public function getDescription(): string
{
return 'dtb_product_classテーブルにmaker_order_flg(boolean)を追加 - メーカー取り寄せフラグ用';
}
public function up(Schema $schema): void
{
// maker_order_flgカラムが存在するかチェック
$schemaManager = $this->connection->createSchemaManager();
// テーブルが存在するかチェック
if (!$schemaManager->tablesExist(['dtb_product_class'])) {
// テーブルが存在しない場合はスキップ
return;
}
$columns = $schemaManager->listTableColumns('dtb_product_class');
$hasMakerOrderFlg = false;
foreach ($columns as $column) {
if ($column->getName() === 'maker_order_flg') {
$hasMakerOrderFlg = true;
break;
}
}
// maker_order_flgカラムが存在しない場合のみ追加
if (!$hasMakerOrderFlg) {
$this->addSql('ALTER TABLE dtb_product_class ADD maker_order_flg BOOLEAN DEFAULT FALSE NOT NULL');
}
}
public function down(Schema $schema): void
{
// maker_order_flgカラムを削除
$schemaManager = $this->connection->createSchemaManager();
if ($schemaManager->tablesExist(['dtb_product_class'])) {
$columns = $schemaManager->listTableColumns('dtb_product_class');
$hasMakerOrderFlg = false;
foreach ($columns as $column) {
if ($column->getName() === 'maker_order_flg') {
$hasMakerOrderFlg = true;
break;
}
}
if ($hasMakerOrderFlg) {
$this->addSql('ALTER TABLE dtb_product_class DROP COLUMN maker_order_flg');
}
}
}
}