无法让Elasticsearch过滤器工作

时间:2016-12-31 14:48:14

标签: elasticsearch elasticsearch-model

使用Elasticsearch 2和Rails 4,使用elasticsearch-model gem

一切都很好,甚至地理距离也在起作用。但是,我无法为我的生活如何使一个简单的布尔过滤器工作。我有一个简单的布尔值'exclude_from_search_results'(当为真时)应该导致从结果中过滤掉记录。

这是我在rails控制器中的查询(没有过滤器):

    @response = Firm.search(
    query: {
      bool: {
        should: [
          { multi_match: {
              query: params[:search],
              fields: ['name^10', 'address_1', 'address_2', 'address_3', 'address_4', 'address_5', 'address_6'],
              operator: 'or'
            }
          }
        ]
      }
    },
    aggs: {types: {terms: {field: 'firm_type'}}}
  )

我在bool或查询部分或者在它之外添加了这个,但是我要么没有文件,要么是所有文件。 (9000应匹配)

示例:

  @response = Firm.search(
    query: {
      bool: {
        should: [
          { multi_match: {
              query: params[:search],
              fields: ['name^10', 'address_1', 'address_2', 'address_3', 'address_4', 'address_5', 'address_6'],
              operator: 'or'
            }
          }
        ],
            filter: {
            term: {"exclude_from_search_results": "false"}
        }
      }
    },
    aggs: {types: {terms: {field: 'firm_type'}}}
  )

我也尝试将filter子句放在不同的地方,但要么得到错误,要么没有结果。我究竟做错了什么??可能缺少简单的东西......

这是我的映射:

    "mappings" : {
  "firm" : {
    "dynamic" : "false",
    "properties" : {
      "address_1" : {
        "type" : "string",
        "index_options" : "offsets",
        "analyzer" : "english"
      },
      "address_2" : {
        "type" : "string",
        "index_options" : "offsets",
        "analyzer" : "english"
      },
      "address_3" : {
        "type" : "string",
        "index_options" : "offsets",
        "analyzer" : "english"
      },
      "address_4" : {
        "type" : "string",
        "index_options" : "offsets",
        "analyzer" : "english"
      },
      "address_5" : {
        "type" : "string",
        "index_options" : "offsets",
        "analyzer" : "english"
      },
      "address_6" : {
        "type" : "string",
        "index_options" : "offsets",
        "analyzer" : "english"
      },
      "exlude_from_search_results" : {
        "type" : "boolean"
      },
      "firm_type" : {
        "type" : "string",
        "index" : "not_analyzed"
      },
      "location" : {
        "type" : "geo_point"
      },
      "name" : {
        "type" : "string",
        "index_options" : "offsets",
        "analyzer" : "english"
      }

任何指针都非常感谢...

1 个答案:

答案 0 :(得分:1)

您当前的查询是在过滤器和多匹配查询之间进行OR。这就是你得到所有文件的原因。

我想你想在过滤器和多匹配查询之间做AND。 如果是这种情况,那么以下查询适用于我。

{
    "query": {
        "bool": {
            "must": [
                {
                    "multi_match": {
                        "query": "address1",
                        "fields": [
                            "name^10",
                            "address1",
                            "address2",
                            "address3",
                            "address4",
                            "address5",
                            "address6"
                        ],
                        "operator": "or"
                    }
                },
                {
                  "term": {
                    "exclude_from_search_results": {
                      "value": "false"
                    }
                  }
                }
            ]
        }
    },
    "aggs": {
        "types": {
            "terms": {
                "field": "name"
            }
        }
    }
}

希望得到这个帮助,谢谢。