ElasticSearch在搜索结果的末尾追加不匹配的文档

时间:2018-09-18 06:28:48

标签: elasticsearch

有什么方法可以在搜索结果的末尾附加不匹配的文档?

我一直在一个项目中,我们需要按地理位置数据搜索文档,但是有些文档没有可用的地理位置数据。因此,这些文档未返回搜索结果。

有什么方法可以在搜索结果的末尾附加不匹配的文档?

映射示例:

PUT /my_locations
{
    "mappings": {
        "_doc": {
            "properties": {
                "address": {
                    "properties": {
                        "city": {
                            "type": "text"
                        },
                        "location": {
                            "type": "geo_point"
                        }
                    }
                }
            }
        }
    }
}

具有地理位置的数据:

PUT /my_locations/_doc/1
{
    "address" : {
        "city: "XYZ",
        "location" : {
            "lat" : 40.12,
            "lon" : -71.34
        }
    }
}

没有地理位置的数据:

PUT /my_locations/_doc/2
{
    "address" : {
        "city: "ABC"
    }
}

有什么方法可以执行地理距离查询,该方法将选择包含地理位置数据的文档,并在结果的末尾附加非地理文档?

https://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-geo-distance-query.html#query-dsl-geo-distance-query

1 个答案:

答案 0 :(得分:1)

您有两个单独的查询

  1. 获取该区域内的文档
  2. 获取其他文档

要一次找到这两个文件,则意味着所有文档都显示在一个结果中,并分享排名。创建一个关联模型很难获得前9个带有地址的文档,而一个没有地址。

但是您可以一次运行两个查询,一个查询,例如带有位置的前9个文档,一个查询,不带位置。

示例:

GET my_locations/_msearch
{}
{"size":9,"query":{"geo_distance":{"distance":"200km","pin.location":{"lat":40,"lon":-70}}}}
{}
{"size":1,"query":{"bool":{"must_not":[{"exists":{"field":"pin.location"}}]}}}