在 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 个位置
我希望你可以帮助我。提前致谢!
MySQL 大圆距离(半正矢公式) https://stackoverflow.com/questions/574691/mysql-great-circle-distance-haversine-formula正是您所需要的。
然而,只有 200 条记录,您也可以加载所有记录并使用代码检查它们。数据集确实太小了,无法过多担心数据库与代码或任何其他此类优化。
在PHP中计算邮政编码之间的距离 https://stackoverflow.com/questions/407989/calculating-distance-between-zip-codes-in-php有几个该算法的 PHP 实现。
地理位置邻近搜索 https://stackoverflow.com/questions/626024/geo-proximity-search与您遇到的问题几乎完全相同。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)