出现的问题:
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了。
问题解决了,但是感觉有点莫名其妙~~~