我需要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循环转换为查询集注释。有帮助吗?
以下是包含相关字段的photo
和photostream
数据模型:
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]
答案 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