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

问题描述

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

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)