[英]serialize self-referential foreign key
Lets say I want to create an article that links via slug to one or multiple other articles (for now one).假设我想创建一篇文章,通过 slug 链接到一篇或多篇其他文章(现在是一篇)。 A post request comes in giving me some article-info and the related slug.
一个帖子请求给了我一些文章信息和相关的 slug。 I want to
我想要
models.py
class Article(models.Model):
heading = models.CharField(max_length=2550)
slug = models.SlugField(null=True, default=None, unique=True, max_length=255)
article_previous = models.ForeignKey('self', to_field='slug', blank=True, null=True,
related_name='subcategories', on_delete=models.DO_NOTHING)
serializers.py
class ArticleSerializer(serializers.ModelSerializer):
class Meta:
model = Article
fields = (
"heading",
"slug",
"article_previous",
def create(self, validated_data):
try:
article_previous = Article.objects.get(slug=d['value'])
article_previous_slug = article_previous.slug
except Article.DoesNotExist:
raise serializers.ValidationError(f'No Article with the slug {d["value"]}')
article=Article.objects.create(**validated_data,article_previous_id=article_previous_slug)
return validated_data
article_previous = serializers.CharField()
ValueError: Cannot assign "'test_1'": "Article.article_previous" must be a "Article" instance. ValueError:无法分配“'test_1'”:“Article.article_previous”必须是“Article”实例。
article_previous = serializers.CharField('article.article_previous')
TypeError: Article() got an unexpected keyword argument 'article' TypeError:Article() 得到了一个意外的关键字参数“文章”
views.py
:views.py
中使用 serializer.validated_data :return Response(serializer.validated_data, status=status.HTTP_201_CREATED, headers=headers)
response = serializer.save()
return Response(response, status=status.HTTP_201_CREATED, headers=headers)
TypeError: Object of type Article is not JSON serializable. TypeError:Article 类型的对象不是 JSON 可序列化的。
You can serialize the slug by working with the article_previous_id
field:您可以通过使用
article_previous_id
字段来序列化 slug:
class ArticleSerializer(serializers.ModelSerializer):
article_previous = serializers.CharField(source='article_previous_id')
class Meta:
model = Article
fields = ('heading', 'slug', 'article_previous')
# …
class ArticleSerializer(serializers.ModelSerializer):
article_previous=serializers.SlugRelatedField(queryset=Article.objects.all(), slug_field="slug")
class Meta:
model = Article
fields = ('heading', 'slug', 'article_previous')
def create(self, validated_data):
article_previous=validated_data.pop("article_previous")
article=Article.objects.create(**validated_data, article_previous=article_previous)
validated_data.update( {"article_previous" : article.article_previous.slug} )
return validated_data
I think this solution has the advantage that the naming stays article_previous
and is not changed to article_previous_id
.我认为这个解决方案的优点是命名保持
article_previous
并且没有更改为article_previous_id
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.