执行python manage.py migrate 没有创建表的解决方案

时间:2024-05-30 19:27:45

问题一:

我对我的models进行了一些修改,需要重新迁移数据
发现我在pycharm中执行python manage.py makemigrations 的时候没有报错,但是执行python manage.py migrate 的时候报错

执行python manage.py migrate 没有创建表的解决方案

原因:
在这里,Django会将我所有的操作,放在这个0001文件中,会记录我曾经做过的操作。
也就是说,我删除了数据库中的表,但是这个文件中记录我已经创建了表,那么将不会创建表。
所以我在执行数据迁移的时候(python manage.py migrate) 他认为没有任何修改

标题执行python manage.py migrate 没有创建表的解决方案

解决方法:

将0001文件删除,再一次执行
python manage.py makemigrations
python manage.py migrate

问题二:

python manage.py migrate 执行的时候依旧报错,提示xxxx表已经存在,我们找到数据库,清空关于django 的所有表的内容并删除表,但是问题又来了,在删除表的时候会提示
Cannot delete or update a parent row: a foreign key constraint fails
这是因为表之间设置了外键,而MySQL是有外键约束的,所以删除不掉这个表

解决方案:
解除外键约束,删除表
执行python manage.py migrate 没有创建表的解决方案

最后都执行之后,记得将外键约束检查添加上,保证MySQL的结构完整
执行python manage.py migrate 没有创建表的解决方案

这次,再次执行两个命令,发现成功。

执行python manage.py migrate 没有创建表的解决方案

总结:

python manage.py makemigrations 表示通知Django即将做什么,并做一个记录,实际上并没有做
python manage.py migrate 真正开始创建数据库

导致错误的原因:我之前创建过models并且创建了对应的表,所以相关的表都是已经创建过的状态,然后我对models进行了修改,而且是修改了表的关系和表的字段,所以出现的这个问题。

提示:

以后创建models应该提前想好再创建,否则容易出现问题。