我无法弄清楚如何序列化包含来自反向相关模型的字段的查询。我的模特看起来像这样。每个投票都与一张专辑相关联:
# models.py
class Album(models.Model):
name = models.CharField(max_length=50)
class Vote(models.Model):
album = models.ForeignKey(Album, on_delete=models.CASCADE)
user_vote = models.BooleanField(default=0)
我想要做的是执行一个返回所有相册对象的查询,以及归因于该相册的投票总和。这很容易,但是当我序列化查询时,“total_votes”字段丢失了:
# views.py
# this works fine
query = Album.objects.annotate(total_votes = Sum(vote__user_vote))
# after serialization, I lose the field "total_votes"
serialized = serializers.serialize('json', list(query))
return serialized
不幸的是,字段“total_votes”没有出现在序列化结果中,因为根据Django文档,“只有在模型上本地定义的字段才会被序列化。”
所以我的问题是,如何得到以下序列化结果(假设Abbey Road有100票,Astral Weeks有150票)?任何帮助将不胜感激。
[
{
"pk": 1,
"model": "app.album",
"fields": {
"name": "Abbey Road",
"total_votes": 100
},
{
"pk": 2,
"model": "app.album",
"fields": {
"name": "Astral Weeks",
"total_votes": 150
},
...
]
答案 0 :(得分:1)
根据消息来源,使用serializers.serialize
无法做到这一点。基本django序列化程序只会序列化模型实例上的local_fields
:
for field in concrete_model._meta.local_fields:
if field.serialize:
if field.remote_field is None:
if self.selected_fields is None or field.attname in self.selected_fields:
self.handle_field(obj, field)
else:
if self.selected_fields is None or field.attname[:-3] in self.selected_fields:
self.handle_fk_field(obj, field)
for field in concrete_model._meta.many_to_many:
if field.serialize:
if self.selected_fields is None or field.attname in self.selected_fields:
self.handle_m2m_field(obj, field)
为了得到你想要的东西,你必须推出自己的序列化函数(例如,将你的模型转换为dict,然后使用DjangoJSONEncoder)。