【问题标题】:Filtering search results with django-haystack / solr produces solr syntax error使用 django-haystack / solr 过滤搜索结果会产生 solr 语法错误
【发布时间】:2016-03-17 10:38:32
【问题描述】:

我想我可能在 haystack / solr 中发现了一个错误,但我不确定,想先看看我是否做错了什么。我正在使用:

django 1.8 干草堆 2.4.1 solr 4.10.4

当我尝试过滤我的 SearchQuerySet 时,SOLR 抱怨从 haystack 生成的过滤查询语法无效。奇怪的是,单步执行 pdb 中的代码是可行的,但在正常情况下都失败了。代码的相关部分是:

    # this is built from a query string but essentially resolves to something like
    applicable_filters = {'job_type__in':['PE', 'TE'], 'sector__in':['12','13']}

    # Do the query.
    sqs = SearchQuerySet().models(self._meta.queryset.model).filter(**applicable_filters).order_by(order).load_all().auto_query(request.GET.get('q', ''))
    if not sqs:
        sqs = EmptySearchQuerySet()

执行此查询时,SOLR 会抛出以下内容:

[vagrant@127.0.0.1:2222] out: Failed to query Solr using '(job_type:("PE" OR "TE") AND sector:("12" OR "13") AND )': [Reason: org.apache.solr.search.SyntaxError: Cannot parse '(job_type:("PE" OR "TE") AND sector:("12" OR "13") AND )': Encountered " ")" ") "" at line 1, column 55.

如您所见,似乎 haystack(或者可能是 pysolr ?)正在向 SOLR 查询添加一个额外的 AND 子句,这似乎完全错误。真正奇怪的是,如果我在 pdb 中逐步执行相同的功能,它就可以工作。

不知所措....

【问题讨论】:

    标签: django solr django-haystack


    【解决方案1】:

    固定。

    问题是我将一个空字符串传递给最终的 auto_query() 子句。我已经从一个 whoosh 后端迁移,它似乎比 SOLR 更能容忍空搜索字符串。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-04-30
      • 2013-08-12
      • 2011-09-25
      相关资源
      最近更新 更多