教义迁移:diff重新生成相同的唯一索引约束

时间:2020-10-20 19:32:17

标签: php symfony doctrine-orm doctrine doctrine-migrations

我有一个奇怪的问题。当我运行doctrine-migrations migrations:diff时,它将重新生成在较早迁移中已设置的索引。

早期迁移(我的数据库中也存在uniq索引):

$this->addSql('CREATE TABLE my_table (id INT AUTO_INCREMENT NOT NULL, email VARCHAR(255) NOT NULL, UNIQUE INDEX UNIQ_4VBV083VA6917B55 (email), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 COLLATE `utf8_unicode_ci` ENGINE = InnoDB');

运行doctrine-migrations migrations:diff后重新生成:

$this->addSql('DROP INDEX uniq_4vbv083va6917b55 ON my_table');
$this->addSql('CREATE UNIQUE INDEX UNIQ_J43107ECE6416I64 ON contact_company (email)');

将小写字母改为大写字母。也许这意味着一些。在我以前的迁移中,我将其大写,并且在数据库中也显示为大写,因此我不知道为什么这里小写。

我在实体中定义了这样的唯一约束:

/**
 * @ORM\Column(type="string", unique=true)
 */
private string $email;

0 个答案:

没有答案