2

当我添加:

fields: [ "doc['Location'].lon" ]

对于我的查询,经度值与文档源中显示的值不同。

在这里,您可以看到我获取 doc['Latitude'].lon 和 .lat 以及要比较的 _source.Latitude 的查询结果:

https://gist.github.com/d9533170f1f50fd27e87(注意——这些在PHP中是通过json_decode传递的,但是使用json_decode之前的数据是一样的。)

当我使用 "doc['field_name'].distance(lat, lon)" 尝试将距离作为字段添加到我的查询时,我首先注意到了这一点。我尝试了“script_fields”和“fields”键,每个键都有相同的结果。

更新:我注意到“doc['Location'].lon”正在返回我认为应该是 doc['Location'].lat 的内容(lat 和 lon 已切换。)

4

1 回答 1

5

问题在于,当使用 GeoJSON 格式(或使用 lat/long 作为数组)时,您必须将lat/lng 的顺序切换为 lng/lat

我正在重建我的索引,但是,为了解决这个问题,我现在使用了这个查询:

doc['Location'].distance( lon + 180, lat ) // Temporary bandaid

一旦我用正确的值重建了索引,我将切换回:

doc['field_name'].distance(lat, lon) // The correct method
于 2011-11-19T19:36:37.873 回答