我有一个名为“StoreItem”的模型和一个名为“QuoteItem”的模型。一个 QuoteItem 指向一个 StoreItem。
我正在尝试注释有多少报价项目指向商店项目的计数器,但条件适用于报价项目。
我试过这样的事情:
items = items.annotate(
quote_count=Count(
Case(
When(quoteitem__lookup_date__in=this_week, then=1),
output_field=IntegerField()
)
)
)
'items' 是 StoreItems 的查询集。'this_week' 是代表本周的日期列表(这是我尝试应用的过滤器)。在我使日期工作正常后,我想为这个条件计数添加更多过滤器,但让我们从它开始。
无论如何,我得到的更像是一个布尔值 - 如果存在符合条件的报价项目,无论我有多少,计数器将为 1。否则,将为 0。
它看起来是Count(Case())
唯一检查是否存在任何项目,如果存在则返回 1,而我希望它遍历指向商店项目的所有报价项目并计算它们,如果它们符合条件(单独)。
我该如何实现?