我有一个带有字段 $usedMB
的实体。我使用 Doctrine2 作为 ORM,使用 DoctrineMigrationsBundle 进行数据库迁移。
/**
* @ORM\Entity
*/
class DeviceStatus
{
...
/**
* @ORM\Column(type="float", nullable=true, options={"unsigned":true})
*/
private $usedMB;
...
}
如果我执行命令php bin/console doctrine:migrations:diff
,我在迁移文件中得到以下行:
ALTER TABLE device_status CHANGE used_mb used_mb DOUBLE PRECISION DEFAULT NULL
之后,我执行命令 php bin/console doctrine:migrations:migrate
,我收到迁移成功执行的消息。
但问题是 - 如果我执行 php bin/console doctrine:migrations:diff
我再次在迁移文件中得到相同的行:
ALTER TABLE device_status CHANGE used_mb used_mb DOUBLE PRECISION DEFAULT NULL
只是指出 - 执行命令之间没有进行任何代码更改。
之后,我执行命令 php bin/consoledoctrine:migrations:migrate,然后再次 - 我收到迁移成功执行的消息。 而且这种情况可能会永远持续下去。
能否解释一下为什么每次都会生成相同的迁移?
最佳答案
问题是处理原则本身的“无符号”选项的错误。
当前存储库中有一个针对此主题的开放错误报告: https://github.com/doctrine/dbal/issues/2380
该修复应该随 v2.6 一起发布
关于mysql - DoctrineMigrationsBundle 每次都会生成相同的迁移,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44799621/