<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
/**
* dtb_product_stockテーブルの無効なproduct_class_idを持つレコードを削除
*/
final class Version20251119161237 extends AbstractMigration
{
public function getDescription(): string
{
return 'dtb_product_stockテーブルの無効なproduct_class_idを持つレコードを削除';
}
public function up(Schema $schema): void
{
// 無効なproduct_class_idを持つレコードを削除
// dtb_product_classテーブルに存在しないproduct_class_idを持つレコードを削除
$this->addSql("
DELETE FROM dtb_product_stock
WHERE product_class_id IS NOT NULL
AND product_class_id NOT IN (SELECT id FROM dtb_product_class)
");
}
public function down(Schema $schema): void
{
// このマイグレーションはデータクリーニングのため、ロールバックは不可能
// 削除されたデータを復元することはできない
}
}