解决Django makemigrations 时的NodeNotFoundError 及 其它迁移问题
当django 环境变了时,原其他环境下的项目不能正常运行,需要进行修改。
常见问题有:
1、首先需要修改url 的方法
2、当执行数据迁移命令时会发生报错,具体报错信息如下:
# 我只截取了最近的报错内容
Traceback (most recent call last):
File "D:\Python368x64\Lib\site-packages\django\db\migrations\graph.py", line 195, in
[n.raise_error() for n in self.node_map.values() if isinstance(n, DummyNode)]
File "D:\Python368x64\Lib\site-packages\django\db\migrations\graph.py", line 58, in raise_error
raise NodeNotFoundError(self.error_message, self.key, origin=self.origin)
django.db.migrations.exceptions.NodeNotFoundError: Migration auth.0012_user_following dependencies reference nonexistent parent node ('account', '0002_contact')
此时新建项目时,执行数据库迁移命令时,可能也会出现该类似问题,这是django的migrations残留了历史对应的迁移数据,这个是 django自身的App造成的,如:admin和 auth应用。因此需要根据报错信息,手动去操作 migrations文件中清除对应的迁移数据文件。
注意:千万不要听信网上很多人说的,删除migrations迁移记录及数据库中表,然后重新执行数据库迁移命令。删除数据库中的数据是大忌,不可取。
可以尝试以下具体操作如下:
1、通过本地的python3.8文件下查询路径进行删除:
2、删除确定出错的迁移文件,在这里就是最后一个0012开头的文件。
3、删除之后重新执行 python3 manage.py makemigrations
4、执行 python3 manage.py migrate
此时迁移操作应该可以正常了。
注:也可以通过pycharm项目下的库进行查找进行删除,路径同上。很方便查找以及操作。
如果出现其他关于数据迁移问题,也可以通过暴力删除方式解决(当然不要删数据库中的数据)。
具体操作如下:
1、首先删除项目中的 migrations.py 文件中的记录
2、去Python库中,删除admin应用和 auth应用下的migrations历史数据
#具体路径:
python3.6--->site-packages--->django--->contrib--->admin(和auth)-->migrations
3、重新执行数据库迁移命令,此方法应该可以解决大部分数据库迁移问题。