Django 迁移与迁移图中的多个叶节点发生冲突

t B*_*ook 16 django django-migrations

使用 Django 1.11.22 我正在尝试运行迁移

python manage.py migrate
django.db.migrations.exceptions.InconsistentMigrationHistory: Migration base.0036_auto_20190227_1226 is applied before its dependency base.0027_auto_20170801_1228_squashed_0037_auto_20190222_1347 on database 'default'.
Run Code Online (Sandbox Code Playgroud)

我第一次尝试解决这个问题是

sudo -u postgres psql -d albatros -c \
"DELETE FROM django_migrations WHERE name = '0036_auto_20190227_1226' AND app = 'base'"
Run Code Online (Sandbox Code Playgroud)

希望从迁移表中删除迁移可以修复它。不幸的是我现在得到:

CommandError: Conflicting migrations detected; multiple leaf nodes in the migration graph: (0037_auto_20190222_1347, 0036_auto_20190227_1226 in base).
To fix them run 'python manage.py makemigrations --merge'
Run Code Online (Sandbox Code Playgroud)

当尝试 makemigrations --merge 时,它​​没有找到任何要合并的迁移。这就是 showmigrations 的样子:

 ./manage.py  showmigrations base
base
 [X] 24_initial
 [X] 24_to_26
 [X] 26_to_27
 [X] 0027_auto_20170801_1228
 [X] 0028_resourcebase_is_approved
 [X] 0029_auto_20171114_0341
 [X] 0030_auto_20180309_0833
 [X] 0031_auto_20180309_0837
 [X] 0032_auto_20180329_1844
 [X] 0033_auto_20180330_0951
 [X] 0034_auto_20180606_1543
 [X] 0035_resourcebase_dirty_state
 [ ] 0036_auto_20190227_1226
 [ ] 0036_auto_20190129_1433
 [ ] 0037_auto_20190222_1347
Run Code Online (Sandbox Code Playgroud)

有人能说一下如何正确应用迁移并解决多叶节点错误吗?

小智 11

在这 2 个迁移文件(0037_auto_20190222_1347、0036_auto_20190227_1226)中,您具有相同的依赖项,请检查它们。它们看起来像是一个包含元组的列表

dependencies = [
    ('round', '0008_auto_20200116_0752'),
]
Run Code Online (Sandbox Code Playgroud)

您需要手动将“0036_auto_20190227_1226”写入0037_auto_20190222_1347文件依赖变量。

  • 你的答案不容易验证。在这种情况下,尝试提供更多背景信息,例如您如何得出结论。 (5认同)