我想我不会正确地解读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()
但是当我执行搜索时,只搜索字段“username”; “twitter_account”被忽略。当我通过dbshell选择Searchresults时,对象包含“user”和“twitter_account”的正确值,但结果页面显示“无结果”:
{% 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 %}
有什么想法吗?
答案 0 :(得分:9)
我想这是因为haystack使用文档字段进行通用搜索,除非你定义了对twitter_account字段等其他字段的特定搜索。
每个SearchIndex都需要 一个(也是唯一一个)字段 文件=真。这表明两者 干草堆和搜索引擎 哪个字段是主要字段 在内搜索。
尝试按如下方式指定索引
class UserProfileIndex(SearchIndex):
text = CharField(document=True, use_template=True)
user = CharField(model_attr='user')
twitter_account = CharField(model_attr='twitter_account')
并创建一个名为的文件 搜索/索引// userprofile_text.txt
将包含以下内容
{{ object.user.get_full_name }}
{{ object.twitter_account}}
现在,当你没有指定索引过滤器时,haystack会搜索这个文件的内容(你可以添加你想要的任何内容)。