根据外部引用的数量过滤 django 对象

Posted

技术标签:

【中文标题】根据外部引用的数量过滤 django 对象【英文标题】:Filter django objects based number of foreign references 【发布时间】:2013-05-12 02:35:18 【问题描述】:

我有一个代表项目列表的对象。每个项目都有一个指向该列表的外键。

class ItemList(Model):
    pass

class Item(Model):
    list = ForeignKey(ItemList, related_name="items")

我想要获取包含项目的项目列表。有什么方法可以在 django 中执行此操作,还是我必须手动从查询结果中删除它们?

【问题讨论】:

【参考方案1】:

我发现我可以通过注释和排除来做到这一点:

ItemList.objects.annotate(num_items=Count('items')).exclude(num_items=0)

【讨论】:

以上是关于根据外部引用的数量过滤 django 对象的主要内容,如果未能解决你的问题,请参考以下文章

ManyToManyField对象上的Django可变数量的过滤器?

通过 ForeignKey 外部引用过滤的汇总子查询注释

Django:使用 Q 对象对任意数量的输入进行动态过滤(OR & AND)

Django 根据列表值过滤对象

使用 Django 根据用户选择的另一个对象属性的值来过滤属性的对象值

如何根据 django 模板中的日期过滤列表