tengo tres modelos simplificados para el ejemplo:Anotar una suma de dos campos multiplicado
class Customer(models.Model):
email = models.CharField(max_length=128)
class Order(models.Model):
customer = models.ForeignKey(Customer)
order_status = models.CharField(blank=True, max_length=256)
class Lineitem(models.Model):
order = models.ForeignKey(Order)
quantity = models.IntegerField(blank=True)
price = models.DecimalField(max_digits=6, decimal_places=2)
Quiero consultar los clientes (posiblemente con un filtro) y anotar el total de ellos han pasado (es decir, la suma más (precio * cantidad)
he intentado:.?
Customer.objects.filter(something).annotate(total_spent=Sum(F('order__lineitem__quantity') * F('order__lineitem__price')))
parecería que suma() no se puede utilizar con F() expresiones ¿hay otra manera de hacer esto
¿Alguna vez conseguir que esto funcione? – dotty
Estoy buscando una solución también – Don
Posible duplicado de [Agregación de Django: Suma de multiplicación de dos campos] (http://stackoverflow.com/questions/12165636/django-aggregation-summation-of-multiplication-of- two -fields) – Louis