Buscando en varias tablas con django-haystack
-
18-09-2019 - |
Pregunta
Tengo los modelos de restaurante y comentarios que se muestran a continuación. El modelo de comentarios tiene una tecla extranjera al restaurante. ¿Cómo puedo realizar una búsqueda en algunos de los campos de restaurantes y en el campo de comentarios del modelo de comentarios que devuelve una lista de instancias de restaurantes?
Gracias
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()
Solución
Creo que deberías leer el manual: http://django-haystack.readthedocs.org/en/latest/tutorial.html
Busque multivalue:
class RestaurantIndex(indexes.SearchIndex):
comments = indexes.MultiValueField()
def prepare_comments(self, obj):
return [a for a in obj.comment_set.all()]
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow