Django使用migrate数据库表无法创建的解决方法
遇到无法创建数据库表,一般有两种情况
第一种情况
更改了models.py 文件,增加或者减少数据表的列,此时如果要将更改同步到数据库中,需要删除对应App下migrations下的xxx_initial.py文件,
比如这个文件App\migrations\0001_initial.py。同时删除数据库中对应的表,删除数据库表django_migrations表下的记录。
此时再次进行
python manage.py makemigrations
python manage.py migrate
第二种情况
这种情况多出现在使用别人的代码的时候,在本机进行配置,设置好数据库之后同步数据库表,此时可以生成migrations文件,并且文件中的数据库表都正常。但是执行python manage.py migrate之后,数据库中只有auth的几个表。
此时可以看一下models.py 文件
如果存在
class Meta:
managed = False
db_table = 'article'
此时可以将managed设置为True,再删除第一种情况的几个文件,进行
python manage.py makemigrations
python manage.py migrate
参考文章:
Django中进行migrate无效,进行sqlmigrate查询发现创建语句都为空。无解。。网上没有任何资料。.
本文地址:https://blog.csdn.net/liu_dongd/article/details/107492392
您可能感兴趣的文章:
如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!
网友评论