sql 经纬度范围检索(谷歌方案)
SELECT id, ( 6371 * acos ( //公里: 6371 英里: 3959 cos ( radians(78.3232) ) * cos( radians( 数据库纬度字段) ) * cos( radians( 数据库经度字段) - radians(65.3234) ) + sin ( radians(78.3232) ) * sin( radians( latitude ) ) ) ) AS distance , name FROM tb_hotel HAVING distance < 0.4 ORDER BY distance LIMIT 0 , 20;
该SQL语句将找到距离纬度:78.3232、经度:65.3234坐标0.4公里里范围内最近的20个位置。它根据该行的经纬度和目标经纬度计算距离,然后只要求距离值小于0.4公里的行,按距离对整个查询排序,并将其限制为20个结果。
转自:https://www.iteye.com/blog/justcoding-2224906 上面有更多的方案