繁体   English   中英

如何计算 Django 中的外键属性值

[英]How to count foreign key attribute values in Django

给定模型设置如下:

class Author(models.Model):
    name = models.CharField(max_length=255)

class Genre(models.Model):
    name = models.CharField(max_length=255)

class Book(models.Model):
    title = models.CharField(max_length=255)
    author = models.ForeignKey(Author, on_delete=models.CASCADE)
    genre = models.ForeignKey(Genre, on_delete=models.CASCADE)

我如何计算每个作者所写的体裁数量? 理想情况下,我想要一本关于每位作者的体裁和书籍数量的字典。

[{id: author.id, genres: {genre.id: number_of_books}}]

这可以通过对每个流派的作者查询轻松实现,但这会导致 [作者数量]*[流派数量] 查询。 如果可能的话,我想找到一种更有效的方法。

我们可以查询Book对象,例如:

from django.db.models import Count, F

qs = Book.objects.annotate(
    author_id=F('author__pk'),
    genre_id=F('genre__pk')
).values('author_id', 'genre_id').annotate(
    num=Count('pk')
).order_by('author_id', 'genre_id')

但这不会给出您在此处指定的格式,但我们可以通过后处理来做到这一点:

from itertools import groupby
from operator import itemgetter

[
    {'id': k, 'genre': { v['genre_id']: v['num'] for v in vs }}
    k, vs for groupby(qs, itemgetter('author_id'))
]

暂无
暂无

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

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