重置Django migration的常见方式

lxz

根据django官方文档建议,开发过程中会把生成的migrations提交到git中。由于各种原因,会有一些场景需要重置migrations,故总结一些常用场景及解决办法。

场景一

不考虑数据库数据,可以完全清空数据库。

步骤:

  1. 删除所有migrations

    find . -path "*/migrations/*.py" -not -name "__init__.py" -delete
    find . -path "*/migrations/*.pyc"  -delete
  2. 删除数据库
  3. 重新生成migrations

    python manage.py makemigrations
    python manage.py migrate

场景二

有时候我们会直接导入完整的数据库,包括数据,这种情况下就不能简单的清空数据库。
这时我们的目的就是:清空数据库的migration history,保证以后的migrate能正常使用,但要保留其他数据。

步骤:

  1. 从数据库中删除所有非0001_initial的migration history

    DELETE FROM django_migrations WHERE app IN ('your','app','labels') AND name != '0001_initial'
  2. 使用migrate命令回滚0001_initial的migration history

    python manage.py migrate --fake your zero
    python manage.py migrate --fake app zero
    python manage.py migrate --fake labels zero
  3. 重新生成0001_initial,如果能保证已有0001_initial已是最新的,可跳过此步

    find . -path "*/migrations/*.py" -not -name "__init__.py" -delete
    find . -path "*/migrations/*.pyc"  -delete
    
    python manage.py makemigrations
  4. 在数据库中生成新的0001_initial记录

    python migrate --fake-initial

阅读 15.4k
217 声望
3 粉丝
0 条评论
你知道吗?

217 声望
3 粉丝
文章目录
宣传栏