如何解决Django:psycopg2.errors.UndefinedColumn:“ pages_page”关系的列“ page_image”不存在
这是一个简短的背景故事。我正在为Django使用mezzanine CMS。我创建了一些从夹层模型继承的模型。这在我的Postgres数据库中引起了一个问题,在两个表中存在一个对象。当我尝试在我的网站上搜索帖子时,我不会从一个表中得到结果。
所以,这是我认为我搞砸了的地方。我将模型恢复为本期之前的状态。这意味着我的数据库中仍然存在这些模型的表格,因此我的搜索功能仍然无法正常工作。我希望这种关系消失,所以我做了一些非常愚蠢的事情,并删除了整个数据库。这对我的本地开发很好,因为我只是重新创建了数据库并进行了迁移。
当我尝试将带有新创建的postgres数据库的我的这个项目部署到DigitalOcean上时,获得以下命令:
$ python manage.py createdb --nodata --noinput
给了我错误:
psycopg2.errors.UndefinedColumn: column "page_image" of "pages_page" relation does not exist
LINE 1: UPDATE "pages_page" SET "page_image" = '',"keywords_string"...
我在这个错误上查找了几个线程,并尝试了这个solution无效的方法:
python manage.py shell
>>> from django.contrib.contenttypes.models import ContentType
>>> ContentType.objects.all().delete()
我也尝试了错误LINE 1: UPDATE "pages_page" SET "page_image" = '',"keywords_string"...
中的建议。奇怪的是,在运行此命令之前,我在page_image
表中看到了pages_page
列。
在这种情况下,我不知道什么代码可能会有所帮助。我不知道如何解决此问题。我该如何进一步解决我的问题?
解决方法
我发现了这个问题。它与true
文件中的EXTRA_MODEL_FIELDS
选项有关。我仍然不确定为什么会导致问题,但这是我的settings.py
代码:
EXTRA_MODEL_FIELDS
以下是导致我的问题消失的原因:
- 我部署的
EXTRA_MODEL_FIELDS = ( ( ...,( "mezzanine.pages.models.Page.page_image","ImageField",(_("Featured Image"),),{"blank": True,"upload_to": "uploads/blog"},... )
命令已被注释掉。 - 我继续进行部署过程
- 一旦我要部署网站,我就再次进行迁移
-
createdb --nodata --noinput
列已自动添加
现在一切正常!我不知道这个答案可能有多大帮助,但是如果有人想谈论他们的问题,我总是可以做得更深入。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。