我是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,但是也有相同的错误。
你能帮我解决这个问题吗?
发布于 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中确认这些表是用新的所有者外键列创建的。
本教程对他们如何处理这些命令没有太多的解释。在我看来。)希望能帮助遇到同样事情的人。
发布于 2015-03-06 04:41:31
使用您的UserSerializer并将其设置为readonly
它应该是
class SnippetSerializer(serializers.ModelSerializer):
class Meta:
model = Snippet
owner = serializers.UserSerializer(read_only=True)
fields = ('id', 'title', 'code', 'linenos', 'language', 'style','owner')https://stackoverflow.com/questions/28892378
复制相似问题