使用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"
}
任何指针都非常感谢...
答案 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"
}
}
}
}
希望得到这个帮助,谢谢。