Mysql 计算一个坐标点与多个点的距离
注意:使用 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;
TRUNCATE(x,2)保留两位小数
查询结果: