首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >OperationalError:(1054,“字段列表”中的“未知列‘snippets_snippet.owner_id”)

OperationalError:(1054,“字段列表”中的“未知列‘snippets_snippet.owner_id”)
EN

Stack Overflow用户
提问于 2015-03-06 04:32:37
回答 2查看 1.4K关注 0票数 0

我是model.py

代码语言:javascript
复制
    from django.db import models
from django.contrib.auth.models import User
from pygments.lexers import get_all_lexers, get_lexer_by_name
from pygments.styles import get_all_styles
from pygments.formatters.html import HtmlFormatter
from pygments import highlight

LEXERS = [item for item in get_all_lexers() if item[1]]
LANGUAGE_CHOICES = sorted([(item[1][0], item[0]) for item in LEXERS])
STYLE_CHOICES = sorted((item, item) for item in get_all_styles())


class Snippet(models.Model):
    created     = models.DateTimeField(auto_now_add=True)
    title       = models.CharField(max_length=100, blank=True, default='')
    code        = models.TextField()
    linenos     = models.BooleanField(default=False)
    language    = models.CharField(choices=LANGUAGE_CHOICES, default='python', max_length=100)
    style       = models.CharField(choices=STYLE_CHOICES, default='friendly', max_length=100)
    owner       = models.ForeignKey('auth.User', related_name='snippets')
    highlighted = models.TextField()

    def save(self, *args, **kwargs):
        lexer               = get_lexer_by_name(self.language)
        linenos             = self.linenos and 'table' or False
        options             = self.title and {'title': self.title} or {}
        formatter           = HtmlFormatter(style=self.style, linenos=linenos, full=True, **options)
        self.highlighted    = highlight(self.code, lexer, formatter)
        super(Snippet, self).save(*args, **kwargs)

    class Meta:
        ordering = ('created',)

这是serializers.py

代码语言:javascript
复制
 class SnippetSerializer(serializers.ModelSerializer):
    class Meta:
        model = Snippet
        owner = serializers.ReadOnlyField(source='owner.username')
        fields = ('id', 'title', 'code', 'linenos', 'language', 'style')

class UserSerializer(serializers.ModelSerializer):
    snippets    = serializers.PrimaryKeyRelatedField(many=True, queryset=Snippet.objects.all())

    class Meta:
        model   = User
        fields  = ('id','username','snippets')

每当我通过API访问客户机时,我都会得到以下错误:

(1054,“字段列表”中的“未知列‘snippets_snippet.owner_id”)

我已经再次删除了数据库和syscdb,但是也有相同的错误。

你能帮我解决这个问题吗?

EN

回答 2

Stack Overflow用户

发布于 2016-12-15 23:22:34

我知道这是旧的,但我正在运行相同的教程(Django Rest框架教程#4),并遇到了同样的问题。我想我应该把这个问题的解决方案发出去,以防其他人也遇到这种情况。

此错误告诉您,代码段表中不存在所有者外键列。这很可能意味着python manage.py migrate步骤无法按照预期的方式在代码段表上创建列。

问题是,在本教程中,他们希望在输入内容之后添加一个表列。这样做将导致在执行迁移时来自django的警告。因此,它们不是这样做的,而是让您删除代码段应用程序中的数据库和迁移文件。(注意:因为这只是一个教程,没有输入真正的数据,所以没关系)。但是,如果这没有正确完成,或者(在我的例子中)您使用的是MySQL (而不是sqlite),并且迁移没有创建新字段(代码段表中的所有者外键列),那么就会发生此错误。

为了修复它,(我正在使用MySQL),我删除了数据库并重新创建了它,然后从代码段/迁移中删除了迁移文件(正如本教程所建议的,并将迁移文件夹保留在适当的位置)。然后做了一个完整的:python manage.py makemigrations,然后是python manage.py migrate。之后,我在mysql中确认这些表是用新的所有者外键列创建的。

本教程对他们如何处理这些命令没有太多的解释。在我看来。)希望能帮助遇到同样事情的人。

票数 2
EN

Stack Overflow用户

发布于 2015-03-06 04:41:31

使用您的UserSerializer并将其设置为readonly

它应该是

代码语言:javascript
复制
class SnippetSerializer(serializers.ModelSerializer):
    class Meta:
        model = Snippet
        owner = serializers.UserSerializer(read_only=True)
        fields = ('id', 'title', 'code', 'linenos', 'language', 'style','owner')
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28892378

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档