从产品列表中获取不同的标题,在django中该产品标题的最小和最大价格



我有一个标题相同但价格不同的产品列表。

这是我的产品型号:

class Product(BaseModel):
title = models.ForeignKey(
ProductTitle,
on_delete=models.CASCADE,
related_name="product_title",
null=True,
blank=True,
)
quantity = models.PositiveIntegerField(default=1)
price = models.FloatField(validators=[MinValueValidator(0.00)])
unit = models.CharField(
max_length=20,
blank=True,
null=True,
help_text="Standard measurement units.eg: kg, meter,etc..",
)
description = models.TextField(
blank=True, null=True, help_text="Short Info about Product"
)
slug = models.SlugField(null=False, unique=True)

假设我有10个相同标题但价格不同的产品,其他产品也一样。现在我想获得单一(不同)产品的特定标题与最小和最大价格的产品,等等。因此,我应该得到橙子的最小和最大价格,苹果的最小和最大价格,等等。

我已经尝试了一些方法,但它不工作。就像在这个查询中,它给了我:

product_qs = (
Product.objects.filter(is_deleted=False)
.order_by("title__title")
.distinct("title__title")
)
p_list = product_qs.values_list("title", flat=True)
product_list = product_qs.filter(title__in=p_list).annotate(
max_price=Max("price"), min_price=Min("price")
)
NotImplementedError at /api/product/unique_product/
annotate() + distinct(fields) is not implemented.

有人能帮我一下吗

from django.db.models import Min, Max
Product.objects.values('title__title').annotate(min_val=Min('price'), max_val=Max('price')).order_by()

这将返回:

包含distinct title,min_pricemax_price的字典列表

SQL等价:

SELECT title, max(price) AS max_val, min(price) AS min_val FROM product_table GROUP_BY title;

值()代表GROUP BY,annotate()代表MIN和MAX:

最新更新