我的函数是否正确计算两个纬度和经度之间的距离?

时间:2011-12-06 09:40:33

标签: mysql

我正在使用mysql。

我想创建一个返回两个坐标之间距离的函数。

我希望以英里为单位获得这个距离。

这是我的代码: -

DROP FUNCTION `checkDistance`//

CREATE DEFINER=`root`@`localhost` FUNCTION `checkDistance`(

lat1 DOUBLE(18,15),

lon1 DOUBLE(18,15),

lat2 DOUBLE(18,15),

lon2 DOUBLE(18,15)

) RETURNS double(18,15)

DETERMINISTIC

BEGIN

                DECLARE delta_lat DOUBLE(18,15);

                DECLARE delta_lon DOUBLE(18,15);

                DECLARE temp1 DOUBLE(18,15);

                DECLARE EARTH_RADIUS DOUBLE(18,15);

                DECLARE distance DOUBLE(18,15);

                SET lat1 = RADIANS(lat1);

                SET lon1 = RADIANS(lon1);

                SET lat2 = RADIANS(lat2);

                SET lon2 = RADIANS(lon2);

                SET delta_lat = lat2 - lat1;

                SET delta_lon = lon2 - lon1;

                SET temp1 = POW(SIN(delta_lat/2.0),2) + COS(lat1) * COS(lat2) * 

POW(SIN(delta_lon/2.0),2);

                SET EARTH_RADIUS = 3956.0;

                SET distance = EARTH_RADIUS * 2 * ATAN2(SQRT(temp1),SQRT(1-temp1));

                RETURN distance;

    END

每当我提供这些参数进行测试时: -

lat1 = 26.860524000000000 lon1 = 75.762005000000000

lat2 = 26.860084000000000 lon2 = 75.761745000000000

然后生成此输出: - 0.008681244150493

但是当我在上面提供一些其他公式时,我会得到另一个结果如下: - 英里= 0.034364904109861

请告诉我哪一个是正确的? 我在网上搜了这么多次,有很多公式来计算这个距离。请检查我的上述代码,如果有问题建议我。我想要非常准确的结果。

提前谢谢你。欢迎您发表您的建议。

1 个答案:

答案 0 :(得分:1)

这看起来像是mercantor投影和harvesine公式。它看起来对我来说。根据您的数据,我得到'距离:0.05531公里'。您可以尝试将EARTH_RADIUS设置为正确的值(6371)。我不确定你为什么选择半径半径。以下是我的来源:http://www.movable-type.co.uk/scripts/latlong.html

相关问题