欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-10-07 21:32:48
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文件,
Django使用migrate数据库表无法创建的解决方法
比如这个文件App\migrations\0001_initial.py。同时删除数据库中对应的表,删除数据库表django_migrations表下的记录。
Django使用migrate数据库表无法创建的解决方法
此时再次进行
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