簡體   English   中英

MySQL 經度緯度不准確

[英]MySQL Longitude Latitude not accurate

我正在嘗試根據經度和緯度選擇附近的所有記錄。

問題是它不准確,例如這個查詢說用戶在 42 公里之外,而實際上它在 65 公里之外。

我已經將 lon 和 lat 值放在一個 php 腳本中,該腳本計算距離屬性,這意味着查詢不正確。

有什么關於它為什么會如此之多的想法嗎?

    SELECT
        id,
        first_name,
        (6371 * acos (
           cos ( radians(latitude) )
           * cos( radians( LAT ) )
           * cos( radians( LON ) - radians(longitude) )
           + sin ( radians(latitude) )
           * sin( radians( LAT ) )
          )
        ) AS distance
    FROM
        users

有效的 PHP 代碼

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

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

想通了,程序中的參數設置為INT而不是DOUBLE

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM