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

2022-08-01,,,,

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

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

下载本文的Word格式文档,以方便收藏与打印。