Django QuerySet按反向ForeignKey匹配的数量排序 [英] Django QuerySet ordering by number of reverse ForeignKey matches

查看:46
本文介绍了Django QuerySet按反向ForeignKey匹配的数量排序的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有以下Django模型:

I have the following Django models:

class Foo(models.Model):
    title = models.CharField(_(u'Title'), max_length=600)

class Bar(models.Model):
    foo = models.ForeignKey(Foo)
    eg_id = models.PositiveIntegerField(_(u'Example ID'), default=0)

我希望返回一个 Foo 对象的列表,这些对象与一个 eg_id 值包含在列表中的 Bar 对象具有反向关系价值.所以我有:

I wish to return a list of Foo objects which have a reverse relationship with Bar objects that have a eg_id value contained in a list of values. So I have:

id_list = [7, 8, 9, 10]
qs = Foo.objects.filter(bar__eg_id__in=id_list)

如何根据相关的 Bar 对象的数量排序匹配的 Foo 对象,这些对象在中具有 eg_id 值id_list ?

How do I order the matching Foo objects according to the number of related Bar objects which have an eg_id value in the id_list?

推荐答案

使用Django可爱的

Use Django's lovely aggregation features.

from django.db.models import Count
qs = Foo.objects.filter(
           bar__eg_id__in=id_list
      ).annotate(
           bar_count=Count('bar')
      ).order_by('bar_count')

这篇关于Django QuerySet按反向ForeignKey匹配的数量排序的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆