【发布时间】:2016-09-05 13:15:58
【问题描述】:
我通过一个 android 应用获取 GPS 位置,然后询问服务器数据库中的哪些记录在它附近。
我怎样才能做到这一点?
假设这些是坐标:
39.017411, -97.251117
我如何要求 PHP 中的数据库只给我包含附近坐标的结果?
【问题讨论】:
-
你能在这里添加你的表结构和架构吗
标签: php android mysql gps location
我通过一个 android 应用获取 GPS 位置,然后询问服务器数据库中的哪些记录在它附近。
我怎样才能做到这一点?
假设这些是坐标:
39.017411, -97.251117
我如何要求 PHP 中的数据库只给我包含附近坐标的结果?
【问题讨论】:
标签: php android mysql gps location
您可以执行如下所述的操作,考虑到您的表格的字段名称是lat 纬度和lng 经度
$lat = 39.017411;
$lng = -97.251117;
$result=mysql_query("SELECT tbl.id, tbl.lat, tbl.lng, 111.045 * DEGREES(ACOS(COS(RADIANS($lat))
* COS(RADIANS(lat))
* COS(RADIANS(lng) - RADIANS($lng))
+ SIN(RADIANS($lat))
* SIN(RADIANS(lat))))
AS distance_in_km
FROM table_name as tbl
ORDER BY distance_in_km ASC
LIMIT 0,1");
if(mysql_num_rows($result)>0)
{
$row=mysql_fetch_assoc($result));
echo $row[lat].";".$row[lng];
}
【讨论】: