首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >原则迁移:diff再生相同的唯一索引约束

原则迁移:diff再生相同的唯一索引约束
EN

Stack Overflow用户
提问于 2020-10-20 19:32:17
回答 1查看 927关注 0票数 6

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

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

代码语言:javascript
复制
$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后重新生成

代码语言:javascript
复制
$this->addSql('DROP INDEX uniq_4vbv083va6917b55 ON my_table');
$this->addSql('CREATE UNIQUE INDEX UNIQ_J43107ECE6416I64 ON contact_company (email)');

注意小写到大写。也许这意味着什么。在我之前的迁移中,我使用了大写,而且它在我的数据库中也显示在上面,所以我不知道为什么这里是小写的。

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

代码语言:javascript
复制
/**
 * @ORM\Column(type="string", unique=true)
 */
private string $email;
EN

回答 1

Stack Overflow用户

发布于 2022-11-11 16:44:43

我也碰到了这个问题。我通过将我的电子邮件列长度更改为191个字符来修正这个问题,这是MySQL (utf8mb4)允许的最大索引。

索引大小:MySQL varchar index length

代码语言:javascript
复制
/**
 * @ORM\Column(type="string", length=191, unique=true)
 */
private string $email;

我为我的字段建立了一个综合索引,并在检查数据库中的索引时注意到,它会读到"email(191),xxxx_id,xxxx_id“。我不知道教条是怎么做的,但我认为它看到191 != 255在这里,并试图一次又一次地重新创建索引。

我正在使用这些包版本:

理论/orm -> 2.12.1

学说/迁移-> 3.5.0

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64452137

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档