#1.两点距离(1.4142135623730951) select st_distance(point(0,0),point(1,1)); select st_distance(point (120.10591, 30.30163),point(120.13026,30.25961)); mysql 5.6 添加
#2.两点球面距离(157249.0357231545m) select st_distance_sphere(point(0,0),point(1,1)); select st_distance_sphere(point (120.10591, 30.30163),point(120.13026,30.25961)); This function was added in MySQL 5.7.6.
不支持的话:
deimiter // drop function if exists Spherical_Distance; create function Spherical_Distance(jin1 double,wei1 double,jin2 double,wei2 double) returns double NO SQL BEGIN declare j1 double; declare w1 double; declare j2 double; declare w2 double; declare R double; set j1 = jin1*PI()/180; set w1 = wei1*PI()/180; set j2 = jin2*PI()/180; set w2 = wei2*PI()/180; set R = 6370986; return R*acos(cos(w1)*cos(w2)*cos(j1-j2)+sin(w1)*sin(w2)); END // delimiter ;