我有3个模型:论坛,线程,帖子和我正在创建一个视图来显示论坛列表.但我也想显示每个论坛的主题数和帖子数.
然后我必须:
>计算每个帖子的帖子数量
>总结每个论坛的每个帖子的帖子数量
我在这里发现了类似的东西:Django: Sum the count of a sub sub foreign object,但答案对我不起作用.
from django.shortcuts import render
from django.template import Context
from django.contrib.auth.decorators import login_required
from django.db.models import Count
from chinwag.models import Forum, Thread, Post
@login_required
def forums(request):
forums = Forum.objects.annotate(num_posts=Count('threads__posts')).all(
).select_related('threads__last_post')
return render(request, 'chinwag/forums.html', Context({
'forums': forums,
}))
是否可以在1个SQL查询中执行此操作?怎么样?
解决方法:
如果我理解正确,你可以使用
Forum.objects.annotate(num_threads=Count('threads__id'),
num_posts=Count('threads__posts__id'))
这会在一个数据库中生成两个注释.
第一个计算论坛上的所有主题,第二个计算论坛所有主题上的所有帖子(假设一个主题是一个带有Form的ForeignKey,另一个是一个带有线程的ForeignKey.
‘threads__posts__id’中的确切命名取决于外键的名称,但如果Django不正确,则会在建议时发出错误.
附:你可以删除.all(),它没有做任何事情.