113 votes

Recherche inverse de clés étrangères dans Django

J'ai un lieu, ce lieu a de nombreux événements qui s'y déroulent. Mes modèles ressemblent à ceci :

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)

J'aimerais afficher tous les événements qui se déroulent dans un lieu donné. Comment puis-je le faire ? Ma vue actuelle ressemble à ceci :

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

180voto

Ric Points 4781

Vous pouvez utiliser events = venue.event_set pour aller dans l'autre sens.

Notez que venue.event_set est un objet de gestion, comme Event.objects Vous pouvez donc appeler .all , .filter , .exclude et similaire sur celui-ci pour obtenir un queryset.

Voir le Documentation sur Django

7voto

rjv Points 1781

Allez dans l'autre sens. Utilisez Event modèle.

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

PS : Je n'ai jamais utilisé get_object_or_404() . Modifiez le code en conséquence.

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X