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; /尼克拉斯 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |