在 PHP 中,我有以下代码用于计算两个位置之间的距离:
<?php
function distance($lat1, $long1, $lat2, $long2) {
// DEGREE TO RADIAN
$latitude1 = $lat1/180*pi();
$longitude1 = $long1/180*pi();
$latitude2 = $lat2/180*pi();
$longitude2 = $long2/180*pi();
// FORMULA: e = ARCCOS ( SIN(Latitude1) * SIN(Latitude2) + COS(Latitude1) * COS(Latitude2) * COS(Longitude2-Longitude1) ) * EARTH_RADIUS
$distance = acos(sin($latitude1)*sin($latitude2)+cos($latitude1)*cos($latitude2)*cos($longitude2-$longitude1))*6371;
return $distance;
}
echo distance(9.9921962, 53.5534074, 9.1807688, 48.7771056); // Hamburg, DE - Stuttgart, DE
?>
但是现在,我想通过 PHP 从我的 MySQL 数据库中选择靠近给定位置的位置:
- 用户进入家乡
- 我的脚本通过 Google API 获取纬度/经度值
- 在我的数据库中,我有大约 200 个位置,其中一个字段用于纬度值,一个字段用于经度值
- 我需要 PHP 和 MySQL 的代码来选择离用户家乡最近的 10 个位置
我希望你能帮助我。提前致谢!