繁体   English   中英

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

[英]OperationalError : (1054, “Unknown column 'snippets_snippet.owner_id' in 'field list'”)

这是model.py

    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

 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,但是出现相同的错误。

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

我知道这很旧,但是我正在运行同一教程( Django Rest Framework教程#4 ),并且遇到了相同的问题。 我以为我会将解决方案发布到该问题上,以防其他人也遇到此问题。

此错误告诉您片段表中不存在所有者外键列。 可能这意味着python manage.py migrate步骤未能按片段表上的预期创建列。

问题在于,在教程中,他们想在输入内容后添加表格列。 这样做会在迁移时导致django发出警告。 因此,与其执行此操作,不如让他们在片段应用中删除数据库和迁移文件。 (注意:由于这只是一个教程,没有输入任何实际数据,因此可以)。 但是,如果此操作未正确完成或(在我的情况下)您使用的是MySQL(而非sqlite),并且迁移未创建新字段(代码段表中的所有者外键列),则会发生此错误。

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

本教程对这些命令的作用没有太多解释。 在我的愚见。 :)希望对遇到同样事情的人有所帮助。

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

它应该是

class SnippetSerializer(serializers.ModelSerializer):
    class Meta:
        model = Snippet
        owner = serializers.UserSerializer(read_only=True)
        fields = ('id', 'title', 'code', 'linenos', 'language', 'style','owner')

暂无
暂无

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

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