最近项目中需要计算一个坐标点与多个点的距离,发现用Python来实现效率很低。经同事推荐,将这些坐标点存入了Mysql数据库,然后用数据库自带的方法st_distance_sphere计算距离。经过比较发现确实效率提高了很多,特此记录一下。
注意:使用st_distance_sphere需要Mysql数据库版本为5.7及以上。
例子:
现数据库表中有如下坐标点数据:

需要找出与第一个坐标点(113.8064049, 22.7300434)相距小于3500米的坐标点(表中共有3500个点)。
sql实现:
select t.num,t.city,t.wgs84_lng,t.wgs84_lat,
TRUNCATE(st_distance_sphere(point (113.8064049, 22.7300434),point(t.wgs84_lng,t.wgs84_lat)),2) as distance
from moran_point t
where t.city = '深圳'
HAVING distance > 0 and distance < 3500
ORDER BY distance;
查询结果:

可以看到,共找出41个满足条件的坐标点,且耗时仅为0.066秒,效率提升非常多。
本文介绍了一种利用Mysql数据库的st_distance_sphere方法高效计算坐标点间地理距离的方法,相较于Python实现,该方法大大提高了计算效率。以深圳为例,从3500个坐标点中快速筛选出距离指定点小于3500米的所有点。
880

被折叠的 条评论
为什么被折叠?



