三个问题,出现在修改models模块的类、字段时,迁移数据时。
问题一:执行python manage.py migrate报错No migrations to apply.
解决办法:
1.删除app项目找那个migrations下的文件记录
2.在django_migrations中删除对应app项目名称的记录(只删对应项目名称!)
3. 执行python manage.py makemigrations
4.执行python manage.py migrate
执行第三步返回成功:
问题二:执行第四步可能会报错如下"Table '表名' already exists:
解决方法:
1. 在项目名的初始化文件中注释掉已存在的表记录,
执行python manage.py migrate
执行成功,数据同步之后,切记去掉在0001_initial.py中的注释,否则后续数据迁移还是会报错。
原因是每一次的迁移都会生成一条记录,而这些记录是依赖于initial.py文件的,如果initial中不存在表,则又会继续创建,和数据库中的表出现重复,所以需要去掉注释
问题三:如果更新的表中有外键是指向需要注释掉的表,那么先把外键字段先注释,数据迁移正常之后,在删除注释掉的字段,再进行同步