Django按最频繁的价值排序

时间:2014-02-09 18:18:36

标签: python sql django django-models django-orm

我有一个代表foodtrucks的模型。

class FoodTruck(models.Model):
    name = models.CharField(max_length=30)
    location = models.TextField()
    creation_date = models.DateTimeField(default=datetime.now)
    start_date = models.DateTimeField(null=True, blank=True)

    def __unicode__(self):
      return self.name

此表中将有许多行具有相同的名称(但位置不同)。在我看来,我想按名称排序列表(出现次数最多)。

示例表:

name | location | creation_date | start_date
clover | ABC | ...
chens | XYZ | ...
clover | ABC | ...

我的目标是列出食品卡车以及它们在过去30天内在所有地点出现的次数,并按照最常见的次序排序。

1 个答案:

答案 0 :(得分:6)

这是一项聚合工作。

from django.db.models import Count
FoodTruck.objects.values_list('name').annotate(truck_count=Count('name')).order_by('-truck_count')