解决Django模型迁移过程中migrate无法更新数据库问题

问题描述:

        由于项目处于开发调试阶段,需要频繁发布,通过jenkins发布后,本地的migrations文件夹也一起同步了。导致发布后makemigrations报错。按照网上的说法是删除自己的APP下migrations除__init__.py所有文件,再执行

python manage.py makemigrations

 python manage.py migrate

第一步OK,但是到了第二步的时候,会报

django.db.utils.OperationalError: (1050, "Table 'asset_info' already exists"),类似的错误,按照网上的资料说删这删那的,结果虽然没报错了,但就是更新不到数据库里,窝火

报这个migrations no changes detected 

解决方法:

网上找到了一篇博文:https://blog.csdn.net/a599174211/article/details/82795206,解决了我的困惑。可能网上之前找的说的都对。主要原因是:一定要先把数据库里的模型和model.py模型对的上,数据库里面少表或者域的话自己手动添加一下,然后按照下面的步骤走一遍:

1、删除指定app下migrations和数据库表django_migrations中和这个app相关的版本号,

2、将模型中的字段和数据库中的字段保持一致,再使用命令python manage.py makemigrations重新生成一个初始化的迁移脚本。

3、再使用命令python manage.py migrare --fake-initial来将这个初始化的迁移脚本标记为已经映射。之后再修改就没有问题了。

    完事儿自己加一个域啥的试试,我自己测了一下没啥问题。

 

你可能感兴趣的:(Django)