执行migrate报错的解决办法:
想知道migrate为什么报错,需要先了解migrate到底做了什么事情
migrate做了什么事情?
1.将相关的迁移脚本翻译成sql语句,然后在数据库中执行
2.如果sql语句执行没有问题,那么会将相关的迁移脚本的名字记录到数据库中django_migrations表中
migrate怎么判断哪些迁移脚本需要执行?
migrate会将代码中的迁移脚本和数据库中的迁移脚本做对比,如果发现数据库中没有这个迁移脚本,便会执行
原因
执行migrate报错,是因为django项目中的迁移脚本和数据库里的django_migrations迁移脚本记录不一致导致报错
解决办法
使用--fake参数
首先对比数据库中的迁移脚本和代码中的迁移脚本,找到哪个不同,然后使用--fake,将代码中的迁移脚本添加到'django_migrations'里,但是不会执行sql语句,这样就避免每次执行migrate的时候重复调用迁移脚本
终极解决方案
如果代码中的迁移脚本和数据库中的脚本实在太多,就是搞不清了,那么这个时候可以用终极解决方案
1.将代码中的迁移脚本和数据库中的迁移脚本全部删除
2.确保app中models的字段和数据库中的字段一致
3.使用 python manager.py makemigrations重新生成迁移脚本
4.使用python manager.py migrate --fake-initial将刚刚生成的迁移脚本,标记为已完成(因为这些模型相对应的表,其实在数据库里都已经存在了,不需要重复执行)