Recherche dans plusieurs tables avec Django-Haystack
-
18-09-2019 - |
Question
J'ai le restaurant et les modèles de commentaires ci-dessous. Le modèle de commentaire a un restaurant Foreignkey to Restaurant. Comment puis-je effectuer une recherche dans certains terrains de restaurants et dans le champ de commentaires du modèle de commentaire qui renvoie une liste des instances de restaurant?
Merci
class Restaurant(models.Model):
name = models.CharField(max_length=100)
country=models.ForeignKey(Country)
city=models.ForeignKey(City)
street=models.CharField(max_length=100)
street_number=models.PositiveSmallIntegerField()
postal_code=models.PositiveIntegerField(blank=True, null=True)
slug = models.SlugField(unique=True)
class Comment(models.Model):
user = models.ForeignKey(User)
restaurant = models.ForeignKey(Restaurant)
submit_date = models.DateTimeField(blank = True, null = False)
comment = models.TextField()
La solution
Je pense que vous devriez lire le manuel: http://django-haystack.readthedocs.org/en/latest/tutorial.html
Recherchez le multivale:
class RestaurantIndex(indexes.SearchIndex):
comments = indexes.MultiValueField()
def prepare_comments(self, obj):
return [a for a in obj.comment_set.all()]
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow