我正在尝试从模型中聚合整数列表。整数派生的字段是@property
装饰器字段。装饰器按预期工作,并且在template.html
内,如果直接传递,则显示没有问题。但是,如果我尝试将@property
字段传递到.aggregate()
,则传递给template
的上下文会抛出一个错误,该错误基本上是Cannot resolve keyword 'sum_thing' into field.
后跟一个模型字段列表不包括任何装饰者字段。
我的问题是 - 如何从模型中汇总(求和)派生字段?
#models.py
class Foo(models.Model):
a = 10 # a & b are both
b = 5 # models.IntegerField() items
@property
def sum_thing(self):
return self.a - self.b
#views.py
class Bar(generic.ListView):
def get_context_data(self, **kwargs):
qs = Foo.object.all()
totals = {}
totals['sumthing'] = qs.aggregate(total=Sum('sum_thing')
context = {
'totals': totals
}
return context
**我大大简化了models.py
和views.py
。
答案 0 :(得分:4)
您无法使用属性进行聚合,因为它不存在于db中。但是,您可以在Django的F
表达式的帮助下对您的查询进行注释,以获取这些字段的实际值。请参阅下面的示例。
from django.db.models import F, Sum
Foo.objects.annotate(sum_a_and_b=F('a') + F('b')).aggregate(total=Sum('sum_a_and_b'))
你也可以做任何数学运算,如/ * + - 用F,你也可以这样做
.annotate(answer=F('a') + F('b') * 2)