django按照多种关系排序

时间:2010-04-11 13:06:55

标签: django

我有以下型号:

class Service(models.Model):
    ratings = models.ManyToManyField(User)

现在,如果我想获得按降序排序的所有服务,我做了一些事情:

services_list = Service.objects.filter(ratings__gt=0).distinct()
services_list = list(services_list)
services_list.sort(key=lambda service: service.ratings.all().count(), reverse=True)

正如你可以看到它的三个步骤,我对此感觉不对。谁知道更好的方法呢?

1 个答案:

答案 0 :(得分:3)

怎么样:

    service_list = Service.objects.annotate(ratings_num=Count('ratings')).filter(ratings_num__gt=0).order_by('-ratings_num')