Pesquisando em várias mesas com django-haystack
-
18-09-2019 - |
Pergunta
Eu tenho o restaurante e os modelos de comentários mostrados abaixo. O modelo de comentário tem uma chave estrangeira para restaurante. Como posso realizar uma pesquisa em alguns dos campos de restaurante e no campo de comentários do modelo de comentários que retorna uma lista de instâncias de restaurantes?
Obrigado
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()
Solução
Eu acho que você deveria ler o manual: http://django-haystack.readthedocs.org/en/latest/tutorial.html
Procure por multivalue:
class RestaurantIndex(indexes.SearchIndex):
comments = indexes.MultiValueField()
def prepare_comments(self, obj):
return [a for a in obj.comment_set.all()]
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow