4

我试图获得两个位置的距离,我真的需要用 mySQL 来完成,因为我必须过滤很多记录。不幸的是,mysql 语句结果与谷歌地图结果不同。可能是什么原因。

我的 Mysql 语句是(硬编码的值)

SELECT ((ACOS(SIN(6.914556 * PI() / 180) * SIN(6.913794 * PI() / 180) + COS(6.914556 * PI() / 180) * COS(6.913794 * PI() / 180) * COS((79.973194- 79.97330) * PI() / 180)) * 180 / PI()) * 60 * 1.609344 * 1000) AS `distance` 

我得到74.27米的距离。

然后我使用了另一个我找到的 SQL 语句,它给出了 85.53 米。

SELECT (1.609344 * 1000 * 3959 * acos( cos( radians(6.914556) ) * cos( radians( 6.913794 ) ) * cos( radians( 79.97330 ) - radians(79.973194) ) + sin( radians(6.914556) ) * sin( radians( 6.913794) ) ) ) AS distance 

但如果我使用谷歌 API

http://maps.googleapis.com/maps/api/directions/json?origin=6.914556,79.973194&destination=6.913794,79.97330&sensor=false

我的距离是 28 米。

无论如何我可以解决这个问题。我需要一个在 MySQL 端工作的解决方案。感谢您的所有支持。

编辑:

我尝试使用 PHP 仍然存在距离差异。

<?php
function distance($lat1, $lon1, $lat2, $lon2, $unit) {

  $theta = $lon1 - $lon2;
  $dist = sin(deg2rad($lat1)) * sin(deg2rad($lat2)) +  cos(deg2rad($lat1)) * cos(deg2rad($lat2)) * cos(deg2rad($theta));
  $dist = acos($dist);
  $dist = rad2deg($dist);
  $miles = $dist * 60 * 1.1515;
  $unit = strtoupper($unit);

  if ($unit == "K") {
    return ($miles * 1.609344);
  } 
  else if ($unit == "M") {
     return ($miles * 1.609344 * 1000);
  }else if ($unit == "N") {
    return ($miles * 0.8684);
  } else {
    return $miles;
  }
}

 function getDrivingDistance($inLatitude,$inLongitude,$outLatitude,$outLongitude)
    {
        if(empty($inLatitude) || empty($inLongitude) ||empty($outLatitude) ||empty($outLongitude))
            return 0;

        // Generate URL
        $url = "http://maps.googleapis.com/maps/api/directions/json?origin=$inLatitude,$inLongitude&destination=$outLatitude,$outLongitude&sensor=false";

        // Retrieve the URL contents
        $c = curl_init();
        curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($c, CURLOPT_URL, $url);
        $jsonResponse = curl_exec($c);
        curl_close($c);

        $dataset = json_decode($jsonResponse);
        if(!$dataset)
            return 0;
        if(!isset($dataset->routes[0]->legs[0]->distance->value))
            return 0;
        $distance = $dataset->routes[0]->legs[0]->distance->value;

        return $distance;
    }
echo distance(6.914556,79.973194,6.913794,79.97330,'M') . "<br>";
echo getDrivingDistance(6.914556,79.973194,6.913794,79.97330);

?>
4

2 回答 2

4

我尝试了大圆公式,结果是 85.5m(你的公式不太正确,但很接近)。与谷歌的不同之处在于谷歌试图计算道路上两点的距离,不知何故,它被投影到道路上的一个点。见下图。(红线是坐标图,距离为 85.5m,蓝线由谷歌渲染,不知何故被“捕捉”到道路上) 实际线是红色的,距离为 85.5m,蓝色线是由谷歌渲染的,被“捕捉”到道路上

于 2013-08-27T08:00:06.750 回答
2

您提供的地图链接有不同的经纬度。

        "northeast" : {
           "lat" : 6.913845999999999,
           "lng" : 79.9733002
        },
        "southwest" : {
           "lat" : 6.913794800000001,
           "lng" : 79.9730488
        }

通过在查询中使用它,它可以提供正确的距离。

于 2013-08-27T07:53:11.263 回答