最近我试图将我的网站上的搜索功能从使用xapian转移到elasticsearch。我在我的应用程序中有两个search_indexes,并在搜索时在页面中并排显示结果。
其中一个search_index是在帐户应用中,用于索引用户模型。在我的代码中,为了只检索用户模型的匹配查询,我正在执行以下操作
users_form = form_class(request.GET, searchqueryset=searchqueryset, load_all=load_all)
users = users_form.search().order_by('date_joined').models(User, )[:8]
我使用的是.model(MODEL_NAME),但显然这不再适用于elasticsearch。
我试图查看弹性搜索的索引详细信息,发现两个索引都是在Index:Haystack和Type:Modelresult下创建的
我不确定如何解决这个问题,以前有人遇到过这个问题?
更新(以下是我的索引):
class UserIndex(indexes.SearchIndex, indexes.Indexable):
text = indexes.CharField(document=True, use_template=True)
username = indexes.CharField(model_attr='username')
date_joined = indexes.DateTimeField(model_attr='date_joined')
full_name = indexes.CharField(model_attr='full_name', )
bio = indexes.CharField(model_attr='bio', null=True)
def get_model(self):
return User
def index_queryset(self, using=None):
return self.get_model().objects.filter(is_active=True, email_is_valid=True)
答案 0 :(得分:1)
我遇到了类似的问题,可以手动过滤内容类型来解决它:
# assuming the app providing your User model is called `auth`
users = users_form.search().order_by('date_joined').filter(django_ct='auth.user')[:8]