django修改model结构 miaration不生效的问题总结

在我们设计好models以后,我们可以通过以下命令生成将要同步给数据库的数据结构文件

 python manage.py makemigrations

生成的文件在app目录下的migrations文件夹内以000*开头的文件。

每运行一次makemigrations,django就会根据models的变更在migrations文件夹内生成一个新文件。

然后我们运行python manage.py migrate,django就会根据migrations文件夹内生成一个文件,将数据结构写入数据库。

那么是不是每一次都重复执行所有的migrations内的文件呢?当然不是,每次执行migrate的时候,django会在django_migrations数据表内记录已经执行了的migrations文件。去数据库里查询该表就能看到对应APP里执行了的migrations。

如果修改了表结构,比如加了一个不能为空的字段,那么即使表中没有数据migration时也会提示:

Please select a fix:
1) Provide a one-off default now (will be set on all existing rows)
2) Quit, and let me add a default in models.py

一般情况下修改了表结构处理方法就是:

第一步,我们需要清理migrations文件夹内除了__init__.py这个文件外的所有文件。(当然部分清理的时候我们也可以考虑直接修改这个文件。)

第二步,我们需要清理数据库内django_migrations对应app下的migrations记录。

清理完以后我们再重新做

python manage.py makemigrations   

python manage.py migrate

如果project下面app数目比较多,修改是针对的单个app下的models,使用命令:

python manage.py makemigrations your_appname

python manage.py migrate

可能会出现警告:

No changes detected

这时利用上述方法可能无解,使用命令:

python manger.py sqlmigrate your_appname 0001

查看migration记录的sql操作命令也可以看到,表结构已经有sql语句修改了,但就是migration不成功。

解决办法就是删除你app中修改model所关联的所有表,不然migration就会报 table已存在的问题,然后再执行migration就ok了。

你可能感兴趣的:(migration,django,web开发,django)