我有一个奇怪的问题。当我运行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;