当我添加:
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被切换.)
问题是当使用GeoJSON格式(或使用lat/long作为数组)时,你必须将lat/lng的顺序切换为lng/lat.
我正在重建我的索引,但是,为了解决这个问题,我现在使用了这个查询:
doc['Location'].distance( lon + 180, lat ) // Temporary bandaid
一旦我用正确的值重建索引,我将切换回:
doc['field_name'].distance(lat, lon) // The correct method