我想要一个用户列表,其中包含他们每个人的费用总额。我只想在应付金额中包括费用。这将返回所有费用的总和,不会过滤掉尚未到期的费用。
user_array = User.objects.all().annotate(
total_sum=Sum('charge__amount', only=Q(charge__due_date__lte=date))
)
最佳答案
尝试
user_array = User.objects.filter(charge__due_date__lte=date).annotate(amount_due=Sum('charge__amount'))
受 https://docs.djangoproject.com/en/1.8/topics/db/aggregation/#order-of-annotate-and-filter-clauses 启发.文档声称只有过滤后的关系值才会被注释。
关于python - Django 注释条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31713152/