Django-解决无法创建表之Table 'XXX' already exists

本文介绍了解决Django项目中出现的迁移错误的方法,包括如何处理表已存在和字段未知等问题,通过删除特定目录和数据库记录,手动更新内容类型表等步骤来确保迁移能够成功。

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

出现的问题:

1、运行以下语句时,可正常运行

python manage.py makemigrations XXX
2、但运行到第二句,报如下错误
python manage.py migrate XXX

_mysql_exceptions.OperationalError: (1050, "Table 'XXX' already exists")


思路:

1、经过把app路径下的migrations目录删除、数据库里django_migrations里对应APP的记录删除,再运行上面两个语句仍然报错。

后来才发现migrations后django_content_type里面没有要新增的表,是没法进行关联的。

django_content_type:记录了当前的Django项目中所有model所属的app(即app_label属性)以及model的名字(即model属性)

表中一条记录对应着一个存在的model,所以可以通过一个ContentType表的id和一个具体表中的id找到任何记录,及先通过ContenType表的id可以得到某个model,再通过model的id得到具体的对象。

2、所以手动在django_content_type表表中增加了对应新增的表记录。

3、然后再重新输入上面两条数据就可以了。

PS:如果把数据库里django_migrations里对应APP的记录删除,需要运行以下语句,同步表结构

python manage.py migrate XXX  --fake

运行上面语句遇到问题:

Unknown column 'name' in 'django_content_ type'

解决:经过把app路径下的migrations目录删除、数据库里django_migrations里对应APP的记录删除,增加的表字段删除,在运行两条语句

python manage.py makemigrations XXX
python manage.py migrate XXX

表字段未更改。然后重新添加字段后,就OK了。

问题解决了,但是感觉有点莫名其妙~~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值