MySQL 函数ST_Distance_Sphere没有使用哈弗森公式吗?



我试图使用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公里的差异,所以结果是非常错误的,请注意,我在两种情况下都使用了完全相同的点和相同的半径,所以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,这是正确的结果。

最新更新