Django 外键反向查找

111 投票
4 回答
159362 浏览
提问于 2025-04-17 18:29

我有一个场地,这个场地会举办很多活动。我的模型大概是这样的:

class Venue(models.Model):
    title = models.CharField(max_length=200)
    date_published = models.DateTimeField('published date',default=datetime.now, blank=True)
    venue_latitude = models.CharField(max_length=200)
    venue_longitude = models.CharField(max_length=200)
    venue_address = models.CharField(max_length=200)
    venue_city = models.CharField(max_length=200)
    venue_state = models.CharField(max_length=200)
    venue_country = models.CharField(max_length=200)
    description = models.TextField()
    def __unicode__(self):
        return u'%s' % (self.title)

class Event(models.Model):
    title = models.CharField(max_length=200)
    date_published = models.DateTimeField('published date',default=datetime.now, blank=True)
    date_start = models.DateTimeField('start date')
    date_end = models.DateTimeField('end date')
    def __unicode__(self):
        return self.title
    description = models.TextField()
    price = models.IntegerField(null=True, blank=True)
    venue = models.ForeignKey(Venue)

我想展示在某个特定场地发生的所有活动。我该怎么做呢?我现在的视图看起来是这样的:

def detail(request, venue_id):
    venue = get_object_or_404(Venue, pk=venue_id)
    return render(request, 'venue-detail.html', {'venue': venue})

4 个回答

7

换个方向思考。使用 Event 模型。

def detail(request, venue_id):
    venue = Event.objects.filter(venue__id=venue_id)
    return render(request, 'venue-detail.html', {'venue': venue})

附注:我从来没有用过 get_object_or_404()。请根据需要修改代码。

10

对于遇到“'RelatedManager'对象不可迭代”的朋友们

可以使用add_all来获取管理器中的所有元素。

{% for area in world_areas.all %}

https://stackoverflow.com/a/16909142/2491526 (无法在第一个答案的评论中添加这个链接)

176

你可以使用 events = venue.event_set 来反向获取数据。

需要注意的是,venue.event_set 是一个管理器对象,类似于 Event.objects,所以你可以在它上面调用 .all.filter.exclude 等方法来获取查询集。

详细信息请查看 Django 文档

撰写回答