私はdjango-haystackを正しく理解していないと思います:
いくつかのフィールドを含むデータモデルがあり、そのうちの2つを検索します。
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を介して検索結果を選択すると、オブジェクトには「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 %}
何か案は?