问题描述
我正在尝试使用 MysqL 计算两个地理点之间的距离,但我认为 ST_distance_Sphere
函数不正确或未使用haversine 公式。
为了描述这个问题,我将使用这两个点和这个地球半径:
Point A: 41.8902142,12.4900422
Point B: 48.8583736,2.2922926
Earth radius: 6378000
我用 JavaScript 编写了这个脚本,它使用了 haversine 公式:
Number.prototype.toRad = function() {
return this * Math.PI / 180;
}
const sin2 = (x) => {
return Math.pow( Math.sin(x),2 );
}
function computedistanceBetween(x1,y1,x2,y2,rad = 6378000) {
const x_diff = x2 - x1;
const y_diff = y2 - y1;
let a = sin2(x_diff.toRad() / 2) + Math.cos(x1.toRad()) * Math.cos(x2.toRad()) * sin2(y_diff.toRad() / 2);
a = 2 * rad * Math.asin(Math.sqrt(a))
return a;
}
console.log(
computedistanceBetween(
41.8902142,12.4900422,48.8583736,2.2922926
) / 1000 // Convert to Km
);
这个脚本给了我这个结果:1110.6415064d524447
,如果我在谷歌地图中检查这个,结果大致相同(1,109.43 km
)
现在,问题是 MysqL,我正试图对这两点做同样的事情,但结果却大不相同:
SELECT
ST_distance_Sphere(
POINT(41.8902142,12.4900422),POINT(48.8583736,2.2922926),6378000
) / 1000 as distances
它给了我 1370.65792958018
作为结果,有 260 Km 的差异,所以结果非常错误,注意我在两种情况下都使用完全相同的点和相同的半径,所以 MysqL 是错误的或者其他的东西?如何获得与 JavaScript 相同的结果,但在 MysqL 中使用空间函数?非常感谢您的帮助
解决方法
好的,这很棘手,函数POINT
首先接收longitude
参数,然后接收latitude
参数,所以,正确的查询应该是这样的:
SELECT
ST_Distance_Sphere(
POINT(12.4900422,41.8902142),POINT(2.2922926,48.8583736),6378000
) / 1000 as distances
所以这会返回我 1110.641506452445
,这是正确的 ?