我正在使用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
请告诉我哪一个是正确的? 我在网上搜了这么多次,有很多公式来计算这个距离。请检查我的上述代码,如果有问题建议我。我想要非常准确的结果。提前谢谢你。欢迎您发表您的建议。
答案 0 :(得分:1)
这看起来像是mercantor投影和harvesine公式。它看起来对我来说。根据您的数据,我得到'距离:0.05531公里'。您可以尝试将EARTH_RADIUS设置为正确的值(6371)。我不确定你为什么选择半径半径。以下是我的来源:http://www.movable-type.co.uk/scripts/latlong.html。