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

在Django中,执行python manage.py migrate未创建表可能是由于历史迁移文件记录了错误的操作。解决方法包括删除0001迁移文件后重新执行makemigrations和migrate,以及在有外键约束的情况下解除约束、删除表后再恢复约束。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题一:

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

在这里插入图片描述

原因:
在这里,Django会将我所有的操作,放在这个0001文件中,会记录我曾经做过的操作。
也就是说,我删除了数据库中的表,但是这个文件中记录我已经创建了表,那么将不会创建表。
所以我在执行数据迁移的时候(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是有外键约束的,所以删除不掉这个表

解决方案:
解除外键约束,删除表
在这里插入图片描述

最后都执行之后,记得将外键约束检查添加上,保证MySQL的结构完整
在这里插入图片描述

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

在这里插入图片描述

总结:

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

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

提示:

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

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

美丽大方程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值