Поиск по нескольким полям
Я думаю, что неправильно понимаю django-haystack:
У меня есть модель данных, содержащая несколько полей, и я хотел бы, чтобы два из них искали:
class UserProfile(models.Model):
user = models.ForeignKey(User, unique=True, default=None)
twitter_account = models.CharField(max_length=50, blank=False)
Мои настройки поискового индекса:
class UserProfileIndex(SearchIndex):
text = CharField(document=True, model_attr='user')
twitter_account = CharField(model_attr='twitter_account')
def get_queryset(self):
"""Used when the entire index for model is updated."""
return UserProfile.objects.all()
Но когда я выполняю поиск, ищется только поле "имя пользователя"; "twitter_account" игнорируется. Когда я выбираю результаты поиска через dbshell, объекты содержат правильные значения для "user" и "twitter_account", но на странице результатов отображается "no results":
{% if query %}
<h3>Results</h3>
{% for result in page.object_list %}
<p>
<a href="{{ result.object.get_absolute_url }}">{{ result.object.id }}</a>
</p>
{% empty %}
<p>No results</p>
{% endfor %}
{% endif %}
Есть идеи?
1 ответ
Я полагаю, это потому, что в стоге сена используется поле документа для общего поиска, если только вы не определите конкретный поиск для других полей, таких как поле twitter_account.
Каждый SearchIndex требует наличия одного (и только одного) поля с document=True. Это указывает и стогу сена, и поисковой системе о том, какое поле является основным полем для поиска внутри.
Попробуйте указать индекс следующим образом
class UserProfileIndex(SearchIndex):
text = CharField(document=True, use_template=True)
user = CharField(model_attr='user')
twitter_account = CharField(model_attr='twitter_account')
и создайте файл с именем search/indexes//userprofile_text.txt
который будет содержать следующее
{{ object.user.get_full_name }}
{{ object.twitter_account}}
Теперь стог сена будет искать в содержимом этого файла (где вы можете добавить все, что вы хотите), когда вы не указали индексный фильтр.