加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 按最近的顺序排序 – PostGIS,GeoRuby,spatial

发布时间:2020-12-17 04:35:14 所属栏目:百科 来源:网络整理
导读:我正在尝试执行查找最接近current_user的记录的订单查询. 我知道这两点之间的距离是:current_location.euclidean_distance(@ record.position) 如何将其用于PostGIS(或active_record / spatial_adapter)查询? 解决方法 要获得最接近的5个: SELECT * FROM
我正在尝试执行查找最接近current_user的记录的订单查询.

我知道这两点之间的距离是:current_location.euclidean_distance(@ record.position)

如何将其用于PostGIS(或active_record / spatial_adapter)查询?

解决方法

要获得最接近的5个:
SELECT * FROM your_table 
ORDER BY ST_Distance(your_table.geom,ST_Geomfromtext(your point as wkt)) 
limit 5;

如果您有一个大数据集,并且知道您不想进一步搜索,例如1 km,那么如果您执行以下操作,查询将更有效:

SELECT * FROM your_table 
WHERE ST_DWithin(your_table.geom,ST_Geomfromtext(your point as wkt,1000)
ORDER BY ST_Distance(your_table.geom,ST_Geomfromtext(your point as wkt))  
limit 5;

/尼克拉斯

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读