出现的问题:
1、运行以下语句时,可正常运行
python manage.py makemigrations XXX2、但运行到第二句,报如下错误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 XXXpython manage.py migrate XXX表字段未更改。然后重新添加字段后,就OK了。
问题解决了,但是感觉有点莫名其妙~~~
本文介绍了解决Django项目中出现的迁移错误的方法,包括如何处理表已存在和字段未知等问题,通过删除特定目录和数据库记录,手动更新内容类型表等步骤来确保迁移能够成功。

3516

被折叠的 条评论
为什么被折叠?



