在Django queryset

时间:2016-04-23 22:21:40

标签: django django-models django-views django-orm

我需要Django注释的帮助。

我有一个名为Photo的Django数据模型,另一个叫PhotoStream(一个PhotoStream可以有很多照片 - 最后的详细模型)。我最简单地通过以下方式获取了200张照片:Photo.objects.order_by('-id')[:200]

对于上述查询集中的每个对象,我想要注释所有相关照片的计数。相关照片是(i)来自相同PhotoStream的照片,(ii)其时间戳小于或等于所讨论对象的时间戳。

换句话说:

for obj in context["object_list"]:
            count = Photo.objects.filter(which_stream=obj.which_stream).order_by('-upload_time').exclude(upload_time__gt=obj.upload_time).count()

我是新手,似乎无法将上面的for循环转换为查询集注释。有帮助吗?

以下是包含相关字段的photophotostream数据模型:

class Photo(models.Model):
    owner = models.ForeignKey(User)
    which_stream = models.ForeignKey(PhotoStream)
    image_file = models.ImageField(upload_to=upload_photo_to_location, storage=OverwriteStorage())
    upload_time = models.DateTimeField(auto_now_add=True, db_index=True)

class PhotoStream(models.Model):
    stream_cover = models.ForeignKey(Photo)
    children_count = models.IntegerField(default=1)
    creation_time = models.DateTimeField(auto_now_add=True)

到目前为止,我的尝试是:

Photo.objects.order_by('-id').annotate(num_related_photos=Count('which_stream__photo__upload_time__lte=F('upload_time')))[:200] 

提供无效的语法错误。

以下内容有效,但不符合上述(ii)中与时间戳相关的要求:

Photo.objects.order_by('-id').annotate(num_related_photos=Count('which_stream__photo'))[:200]

1 个答案:

答案 0 :(得分:0)

我打破了查询,如下所示:

Photo.objects.filter(which_stream__photo__upload_time__lte=F('upload_time')).annotate(num_related_photos=Count('which_stream__photo')).order_by('-id')[:200]

它看起来违反直觉,但是因为它创建底层SQL的方式而起作用。这里有很好的解释:https://stackoverflow.com/a/7001419/4936905