Django外键反向查找

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django外键反向查找相关的知识,希望对你有一定的参考价值。

我有一个场地,该场地上发生了许多事件。我的模型如下:

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)

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)

我想显示在某个特定地点发生的所有事件。我怎样才能做到这一点?我当前的视图如下:

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

您可以使用events = venue.event_set进行其他操作。

请注意,venue.event_set是一个管理器对象,类似于Event.objects,因此您可以在其上调用.all.filter.exclude等类似对象以获取查询集。

请参见Django documentation

另一答案

对于那些具有“'RelatedManager'对象是不可迭代的”对象的]

全部添加以从管理器中检索元素。

% for area in world_areas.all %

https://stackoverflow.com/a/16909142/2491526(无法将其添加到第一个答案的注释中)

另一答案

反过来。使用Event模型。

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

PS:我从未使用过get_object_or_404()。相应地修改代码。

以上是关于Django外键反向查找的主要内容,如果未能解决你的问题,请参考以下文章

Django 查询集外键

Django,从反向外键查询添加数据(外键加入过滤器)

父模型具有多个外键时的Django外键反向访问[重复]

Django级联删除反向外键

在main函数中使用django模型(附django正反向的外键关联查询)

在模板中将外键反向到 django-fts 可搜索模型