No migrations to apply

三个问题,出现在修改models模块的类、字段时,迁移数据时。

问题一:执行python manage.py migrate报错No migrations to apply.

No migrations to apply

解决办法:

1.删除app项目找那个migrations下的文件记录

2.在django_migrations中删除对应app项目名称的记录(只删对应项目名称!)

3. 执行python manage.py makemigrations

4.执行python manage.py migrate

No migrations to apply

执行第三步返回成功:

No migrations to apply

问题二:执行第四步可能会报错如下"Table '表名' already exists:

No migrations to apply

 

解决方法:

1. 在项目名的初始化文件中注释掉已存在的表记录,

  执行python manage.py migrate

No migrations to apply

执行成功,数据同步之后,切记去掉在0001_initial.py中的注释,否则后续数据迁移还是会报错。

原因是每一次的迁移都会生成一条记录,而这些记录是依赖于initial.py文件的,如果initial中不存在表,则又会继续创建,和数据库中的表出现重复,所以需要去掉注释

No migrations to applyNo migrations to apply

问题三:如果更新的表中有外键是指向需要注释掉的表,那么先把外键字段先注释,数据迁移正常之后,在删除注释掉的字段,再进行同步