我知道如何使用 near
方法来获得一定半径内的所有结果,但如何获得所有结果并按距离排序?
我知道我可以做这样的事情:
Location.near(my_location, 999999, order: 'distance')
但是,我宁愿完全跳过半径检查,而只是按距离排序所有结果。
最佳答案
我遇到了同样的问题,我最终将此范围添加到我的地理编码类中:
class A
extend Geocoder::Model::ActiveRecord
reverse_geocoded_by :latitude, :longitude
scope :with_distance_to, ->(point) { select("#{table_name}.*").select("(#{distance_from_sql(point)}) as distance") }
end
这将允许你做
A.with_distance_to(point).order('distance')
关于ruby-on-rails - 地理编码器 : How get all results and order by distance?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24793235/