当前位置: 移动技术网 > IT编程>脚本编程>Python > Django使用migrate数据库表无法创建的解决方法

Django使用migrate数据库表无法创建的解决方法

2020年07月22日  | 移动技术网IT编程  | 我要评论
Django使用migrate数据库表无法创建的解决方法遇到无法创建数据库表,一般有两种情况第一种情况第二种情况遇到无法创建数据库表,一般有两种情况第一种情况更改了models.py 文件,增加或者减少数据表的列,此时如果要将更改同步到数据库中,需要删除对应App下migrations下的xxx_initial.py文件,比如这个文件App\migrations\0001_initial.py。同时删除数据库中对应的表,删除数据库表django_migrations表下的记录。此时再次进行p

Django使用migrate数据库表无法创建的解决方法

遇到无法创建数据库表,一般有两种情况

第一种情况

更改了models.py 文件,增加或者减少数据表的列,此时如果要将更改同步到数据库中,需要删除对应App下migrations下的xxx_initial.py文件,
0001_initial.py位置
比如这个文件App\migrations\0001_initial.py。同时删除数据库中对应的表,删除数据库表django_migrations表下的记录。
数据库中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

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网