来自 3 级嵌套的 Django ORM 求和价格
Django ORM sum prices from 3 level nested
我有这些模型和经理:
class ItemManager(models.Manager):
use_for_related_fields = True
def get_queryset(self):
qs = super().get_queryset()
return qs.annotate(total_price=ExpressionWrapper(
F('gross_price') * F('qty'), output_field=models.DecimalField())
)
class OrderManager(models.Manager):
use_for_related_fields = True
def get_queryset(self):
qs = super().get_queryset()
return qs.annotate(total_price=Sum(items__total_price)) # this doesnt work
class Order(models.Model):
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
name = models.CharField(max_length='50')
class Item(models.Model):
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
price = models.DecimalField(max_digits=14, decimal_places=2)
qty = models.IntegerField()
order = models.ForeignKey(Order, related_name='items', on_delete=models.CASCADE)
objects = ItemManager()
我想获取订单的总价,像这样:
for sale in Order.objects.all():
print(sale.total_price)
错误:
django.core.exceptions.FieldError: Unsupported lookup 'total_price' for UUIDField or join on the field not permitted.
我可以得到每个项目的 total_price
,我想用它 total_price
来获得所有项目的总和。
我需要这种方式,因为我将在具有多个订单作为子元素的模型中使用该销售 total_price。
如果您查询相关模型,这些相关模型不是"pass through".objects
经理。您可以覆盖 ._base_manager
等。但我强烈反对这样做。
您可能最好在 OrderManager
中完成工作:
class OrderManager(models.Manager):
use_for_related_fields = True
def get_queryset(self):
return super().get_queryset().annotate(
<b>total_price=Sum(F('items__price') * F('items__qty'))</b>
)
我有这些模型和经理:
class ItemManager(models.Manager):
use_for_related_fields = True
def get_queryset(self):
qs = super().get_queryset()
return qs.annotate(total_price=ExpressionWrapper(
F('gross_price') * F('qty'), output_field=models.DecimalField())
)
class OrderManager(models.Manager):
use_for_related_fields = True
def get_queryset(self):
qs = super().get_queryset()
return qs.annotate(total_price=Sum(items__total_price)) # this doesnt work
class Order(models.Model):
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
name = models.CharField(max_length='50')
class Item(models.Model):
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
price = models.DecimalField(max_digits=14, decimal_places=2)
qty = models.IntegerField()
order = models.ForeignKey(Order, related_name='items', on_delete=models.CASCADE)
objects = ItemManager()
我想获取订单的总价,像这样:
for sale in Order.objects.all():
print(sale.total_price)
错误:
django.core.exceptions.FieldError: Unsupported lookup 'total_price' for UUIDField or join on the field not permitted.
我可以得到每个项目的 total_price
,我想用它 total_price
来获得所有项目的总和。
我需要这种方式,因为我将在具有多个订单作为子元素的模型中使用该销售 total_price。
如果您查询相关模型,这些相关模型不是"pass through".objects
经理。您可以覆盖 ._base_manager
等。但我强烈反对这样做。
您可能最好在 OrderManager
中完成工作:
class OrderManager(models.Manager):
use_for_related_fields = True
def get_queryset(self):
return super().get_queryset().annotate(
<b>total_price=Sum(F('items__price') * F('items__qty'))</b>
)