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

我正在尝试执行查找最接近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;

/尼克拉斯

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...