gpt4 book ai didi

python - Django 中如何统计外键属性值

转载 作者:行者123 更新时间:2023-12-01 06:44:42 25 4
gpt4 key购买 nike

给定的模型设置如下:

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'))
]

关于python - Django 中如何统计外键属性值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59286317/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com