关于Django无法同步数据库及数据表的解决办法

Posted meipu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于Django无法同步数据库及数据表的解决办法相关的知识,希望对你有一定的参考价值。

问题情景:
遇到一个Django项目,是一个数据展示的界面,类似商品展示

需求:

需要加上登录和注册功能

进展:

在models文件中新增user表后,执行以下两条命令皆无任何响应。

1 python manage.py makemigrations
2 python manage.py migrate

随后查阅相关资料和官方文档找到解决办法,在此之前,简短描述下问题的起因经过。

1.在项目目录中以及app层目录下,即/project/templates和/project/templates、/project/__pycache__三个文件中记录着关于Django对数据库中的操作记录

2.当需要对数据库进行相关更改的情况下,此三个文件夹会有相关记录,例如第一遍执行了上面两条语句,顺利创建了表,后续又删除了表,此中记录并不会被删除,当执行第一条语句的情况下,Django查阅三个文件中的记录以后,发现已经执行了相关操作,也就并不会继续创建表。

在这里并不列举亲测过并不成功的方法,以下按照顺序执行,即可解决问题:

1.在数据库中的目标表存在的情况下,应当删除这些目标表,比如需要对user表进行更改,那么先删除user表,如果需要对data表进行更改,便删除user表,以此类推。

2.删除在项目目录中以及app层目录下,即/project/templates和/project/templates、/project/__pycache__三个文件,如果是文件夹,直接删除文件夹,如果是文件,直接删除文件。

比如  ../项目/  和  ../项目/app01  这样的路径.

上述两步执行完毕后执行下面三条语句:

1 # 此命令用于制作一个空的迁移文件(Django会将文件放在正确的位置,提供一个名称,并为您添加依赖项)
2 python manage.py makemigrations --empty 你的app名
3 python manage.py makemigrations
4 python manage.py migrate

即可完成models中数据库变更操作。

以上是关于关于Django无法同步数据库及数据表的解决办法的主要内容,如果未能解决你的问题,请参考以下文章

关于Django无法启动数据库和无法命令行启动manage.py的解决方法

关于ECShop管理中心无法登录的解决办法

3.django连接mysql数据库及安装mysqldb驱动报错解决办法

MySQL主从同步延迟原因及解决办法

MySQL主从同步延迟原因及解决办法

MySQL主从同步延迟原因及解决办法