解决Django模型迁移过程中migrate无法更新数据库问题
问题描述: 由于项目处于开发调试阶段,需要频繁发布,通过jenkins发布后,本地的migrations文件夹也一起同步了。导致发布后makemigrations报错。按照网上的说法是删除自己的APP下migrations除__init__.py所有文件,再执行python manage.py makemigrations python manage.py 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来将这个初始化的迁移脚本标记为已经映射。之后再修改就没有问题了。
完事儿自己加一个域啥的试试,我自己测了一下没啥问题。
更多推荐
所有评论(0)