使用Geocoder对特定半径内的帖子进行ActiveRecord查询吗?

时间:2018-07-21 18:14:02

标签: mysql ruby activerecord geolocation rails-geocoder

我有以下MYSQL表模式,其中包含记录了他们的纬度和经度的帖子:

+------------+--------------+------+-----+---------+----------------+
| Field      | Type         | Null | Key | Default | Extra          |
+------------+--------------+------+-----+---------+----------------+
| id         | int(11)      | NO   | PRI | NULL    | auto_increment |
| user       | varchar(128) | NO   |     | NULL    |                |
| content    | varchar(512) | NO   |     | NULL    |                |
| timestamp  | varchar(128) | NO   |     | NULL    |                |
| longtitude | double       | NO   |     | NULL    |                |
| latitude   | double       | NO   |     | NULL    |                |
+------------+--------------+------+-----+---------+----------------+

借助geocoder宝石,我可以使用一种方法来计算两个纬度长的坐标之间的距离。

find the distance between two arbitrary points
Geocoder::Calculations.distance_between([47.858205,2.294359], [40.748433,-73.985655])
 => 3619.77359999382 # in configured units (default miles)

我想从表中检索一组记录。我知道我可以得到10条记录的批次,使用以下查询按时间排序:

  record = Post.order(:timestamp).offset(10 * @var.to_i).first(10)

如何修改此查询,以使所有帖子都在一定半径内?即仅显示坐标位于当前用户位置5公里以内的帖子?

如果有问题,我正在使用Sinatra而不是Rails。

1 个答案:

答案 0 :(得分:1)

您可以使用geocoder提供的near方法:

Post.near([lat, lon], 5)

如他们的文档所述,您需要将其添加到模型中:

extend Geocoder::Model::ActiveRecord

参考:https://github.com/alexreisner/geocoder#for-activerecord-models