0

我正在使用地理编码器。我想靠近位置,但它返回一个空数组。

在数据库中得到这个:

"id": 5,
"name": "sogra2",
"lat": "-22.833575",
"long": "-43.312882",

这是我使用近坐标的动作

def near
  @near = Test.near([-22.844279, -43.306174], 100, :units => :km)
  render json: @near
end

这是我的模型:

class Test < ApplicationRecord
  reverse_geocoded_by :lat, :long
end

发布查询

SELECT tests.*, (111.19492664455873 * ABS(tests.lat - -22.844279) *
0.7071067811865475) + (96.29763124613503 * ABS(tests.long - -43.306174) * 0.7071067811865475) AS distance, CASE WHEN (tests.lat >= -22.844279 AND tests.long >= -43.306174) THEN 45.0 WHEN (tests.lat < -22.844279 AND tests.long >= -43.306174) THEN 135.0 WHEN (tests.lat < -22.844279 AND tests.long < -43.306174) THEN 225.0 WHEN (tests.lat >= -22.844279 AND tests.long < -43.306174) THEN 315.0 END AS bearing FROM "tests" WHERE (tests.lat BETWEEN -23.74360060591873 AND
-21.94495739408127 AND tests.long BETWEEN -44.282039151718706 AND -42.33030884828129) ORDER BY distance ASC

它回来了[]

Rails 5.1 API 模式

4

1 回答 1

0

你使用rails > 4.1吗?

Rails 4.1 及更高版本的注意事项

由于 ActiveRecord 的计数方法发生了变化,因此在使用近范围时,您将需要使用count(:all)显式计数所有列。("*")在许多情况下,使用 near 和不带参数调用 count 会导致异常。

于 2017-12-15T08:03:19.407 回答