我做了一个迁移,添加了一个新表,想要恢复它并删除迁移,而不创建一个新的迁移。

我该怎么做?是否有恢复上次迁移的命令,然后我可以简单地删除迁移文件?


当前回答

下面是我的解决方案,因为上面的解决方案并没有真正涵盖使用RunPython时的用例。

可以通过ORM with访问该表

from django.db.migrations.recorder import MigrationRecorder

>>> MigrationRecorder.Migration.objects.all()
>>> MigrationRecorder.Migration.objects.latest('id')
Out[5]: <Migration: Migration 0050_auto_20170603_1814 for model>
>>> MigrationRecorder.Migration.objects.latest('id').delete()
Out[4]: (1, {u'migrations.Migration': 1})

因此,您可以查询这些表并删除与您相关的条目。这样您就可以详细地进行修改。使用RynPython迁移,您还需要处理添加/更改/删除的数据。上面的例子只显示了如何通过Djang ORM访问表。

其他回答

我在1.9.1中这样做了(删除最后或最新创建的迁移):

Rm <appname>/migrations/<migration #>* .使用实例 例如:rm myapp/migrations/0011* 登录到数据库并运行SQL语句(本例中为postgres) 删除django_migrations中名称为“0011%”的位置;

然后,我可以创建新的迁移,以刚才删除的迁移编号(在本例中为11)开始。

如果您在恢复迁移时遇到了麻烦,并且在某种程度上搞砸了它,那么您可以执行假迁移。

./manage.py migrate <name> --ignore-ghost-migrations --merge --fake

对于django版本小于1.7的版本,这将在south_migrationhistory表中创建条目,你需要删除该条目。

现在您可以轻松地恢复迁移。

PS:我被困了很长时间,执行假迁移,然后返回帮助我解决了问题。

您可以通过迁移到以前的迁移进行恢复。

例如,如果你的最后两次迁移是:

0010年_previous_migration 0011年_migration_to_revert

然后你会这样做:

./manage.py migrate my_app 0010_previous_migration 

您实际上不需要使用完整的迁移名称,数量就足够了,即。

./manage.py migrate my_app 0010 

然后可以删除迁移0011_migration_to_revert。

如果你使用的是Django 1.8+,你可以显示所有迁移的名称

./manage.py showmigrations my_app

要反转应用程序的所有迁移,你可以运行:

./manage.py migrate my_app zero

所有其他答案都非常适合回滚线性迁移。然而,当迁移是非线性的,即有多个叶节点,我们希望只回滚一条路径,那么我们可以这样做:

    X
  /   \
 A      B      [A and B can represent any number of linear migrations.] 
  \   /
    Y (merge migration)

如果我们需要回滚A,B和y,那么我们可以用其他答案状态的方式来做。 即python manage.py迁移应用X。

如果只需要取消回滚B和回滚Y,请执行以下步骤:

通过执行python manage.py迁移应用程序B(或A;这两个作品)。 暂时从项目位置移除迁移文件A和Y。 现在取消应用B,执行python manage.py迁移应用X。

将迁移文件A和Y带到原始位置。现在,如果您愿意,您可以安全地删除未应用的迁移B和Y。

要点是django只能回滚迁移,如果文件在位置中。如果您不想回滚一个迁移路径(例如这里的a),请在执行回滚时将其从项目位置中移除。

更多关于这个。https://stackoverflow.com/a/71231925/8663277

有一个很好的库可以使用它叫djagno-nomad,虽然没有直接关系到所问的问题,想分享这个,

场景:大多数情况下,当切换到项目时,我们觉得它应该恢复我们在当前分支上所做的更改,这正是这个库所做的,下面签出

https://pypi.org/project/django-nomad/