django - 从多对一关系中获取对象集

时间:2013-11-05 22:03:59

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

请看看这些型号:

class Album(models.Model):
    user = models.ForeignKey(User)
    name = models.CharField(max_length=200)
    pub_date = models.DateTimeField(default=datetime.now)


class Photo(models.Model):
    album = models.ForeignKey(Album, default=3)
    image = models.ImageField(upload_to=get_upload_file_name)
    caption = models.CharField(max_length=200)
    pub_date = models.DateTimeField(default=datetime.now)

如何获取特定相册的照片集???如何从照片 实例本身获取相册

我试过了:

# To get the set of photos from the user (tika) album:
>>>t = User.objects.get(username='tika')
>>>t_album = Album.objects.get(user=t)
>>>t_album 
<Album: tika_album>
>>>t_album.image_set.all()
AttributeError: 'Album' Object has no attribute 'image_set'

请指导我正确的方向。谢谢。

2 个答案:

答案 0 :(得分:15)

你快到了。您应该使用photo_set代替image_set

>>>t_album.photo_set.all() 

,即_set

的小写型号

如果您想要1个查询中的照片列表,

photos = Photo.objects.filter(album__user__username='tika')

答案 1 :(得分:13)

更好的是,您可以在Photo

中撰写
album = models.ForeignKey(Album, related_name='photos', default=3)

photos将是从AlbumPhoto的反向字段的名称。如果您没有定义它,则反向字段将命名为photo_set

然后使用

t_album.photos.all()  # only if you've defined the `related_name` argument to 'photos'

t_album.photo_set.all()