我如何在django-haystack搜索查询中使用布尔字段

时间:2012-08-16 21:01:07

标签: django elasticsearch django-haystack

我正在使用django-haystack来搜索我的应用程序,我有布尔字段我想过滤我的模型。但是,当我尝试这样做时,我的搜索查询失败。

我正在使用的搜索后端是elasticsearch

2 个答案:

答案 0 :(得分:5)

在此处发布您的一些代码有助于找出问题所在,因为很难排除任何问题。

我是如何实现这一点的(使用whoosh而不是elasticsearch,但django代码应该是相同/相似的),就像这样:

创建了我自己的搜索表单类(如果您还没有这样做,请查看Haystack Docs - Creating your own form

from django import forms
from haystack.forms import SearchForm

class PaidPropertySearchForm(SearchForm):
    q = forms.CharField(required=False, label=('Town Area'))
    #othersearchtermshere
    furnished = forms.BooleanField(required=False)

    def search(self):
        sqs = super(PaidPropertySearchForm, self).search()
        #other search filtering here
        if self.is_valid() and self.cleaned_data['furnished']:
            sqs = sqs.filter(furnished__contains=self.cleaned_data['furnished'])

        return sqs

相关模型领域很简单:

class Properties (models.Model):.
    furnished = models.BooleanField()

和我的searchindexes.py:

class PropertyIndex(indexes.SearchIndex, indexes.Indexable):
    #other indexed terms
    furnished = indexes.BooleanField(model_attr='furnished', default='false')

这里值得注意的是,haystack和使用布尔值的whoosh后端之间存在一些问题,这要求我将defult索引值指定为字符串'false'而不是布尔值False。如果我没有这样做或没有设置默认值,由于某种原因,无论模型存储了什么,所有布尔值都被索引为True。我不知道这个问题是否会影响elasticsearch,所以你可能不需要

default='false'

在搜索索引中

希望如果您还没有弄明白,这有助于您走上正确的轨道。

答案 1 :(得分:4)

sqs = sqs.filter(boolean_field=True) 

对我来说也不起作用(使用Haystack 2.1.0和Elasticsearch 1.2.1),但

sqs = sqs.filter(boolean_field=1)

一样。