[英]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.