繁体   English   中英

django.db.utils.OperationalError:没有这样的表:blog_category

[英]django.db.utils.OperationalError: no such table: blog_category

当我尝试运行python3 manage.py makemigrationspython3 manage.py migrate时,我不断收到错误消息

我检查了很多帖子,他们都说要运行python3 manage.py makemigrations和 python3 manage.py migrate甚至是python3 manage.py migrate --run-syncdb但问题是当我运行这些时我得到了这个错误命令以及当我运行python3 manage.py runserver时:

return Database.Cursor.execute(self, query, params)
    django.db.utils.OperationalError: no such table: blog_category

另一个问题是我没有任何代码说blog_category所以我什至不知道 django 是从哪里得到的。 我尝试了不同的 venv 来查看其他已安装的程序是否有问题,但错误仍然存​​在。 请帮忙。

我也有这个问题。 即使在手动删除迁移后,我也无法进行新的迁移。 我注意到我的 db.sqlite3 文件在从 github 分叉我的项目后变成了一个文本文件。

以下是您可以执行的操作:

  • 确保项目根文件夹中的 db.sqlite3 文件具有扩展名“.sqlite3”,不应没有文件扩展名。 还要确保它不是一个空文件 (0 KB)。

您应该无法打开 db 文件并看到以下内容: 在此处输入图像描述

这不是应该的。 解决此类问题的方法是从另一个项目复制 db.sqlite3 文件(否则它将继续生成错误的文件)。 然后对 admin.py 或 models.py 进行一些更改,以便数据库意识到它需要做一些事情(进行迁移),然后幸运的是 - 您现在应该能够进行迁移(python manage.py makemigrations)。

如果以上不提供解决方案,您可以通过以下方式完全重置数据库:

    python manage.py flush  

再次创建超级用户并进行任何必要的迁移:

    python manage.py createsuperuser
    python manage.py makemigrations
    python manage.py migrate

确保您的项目中没有活动代码会尝试从不再存在的数据库表中查询数据也很重要。 意识到您现在有一个空数据库。

如果我在项目中运行的代码会尝试从过去曾经存在的数据库 object 中检索数据,例如:

 p = Category.objects.get(title=flower_type)

 print(p.flower_set.first())
 print(p.flower_set.last())

这会导致问题,因为没有数据库条目,也没有要查询的数据。 这是需要注意的事情。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM