SELECT id, ( 6371 * acos ( cos ( radians(78.3232) ) * cos( radians( 数据库纬度字段) ) * cos( radians( 数据库经度字段) - radians(65.3234) ) + sin ( radians(78.3232) ) * sin( radians( 数据库纬度字段 ) ) ) ) AS distanceFROM tb_hotel HAVING distance < 0.4 ORDER BY distance LIMIT 0 , 20;
"distance"字段, 数据单位为公里 ( KM ) 。
该SQL语句将找到距离纬度:78.3232、经度:65.3234坐标0.4公里里范围内最近的20个位置。它根据该行的经纬度和目标经纬度计算距离,然后只要求距离值小于30公里的行,按距离对整个查询排序,并将其限制为20个结果。
在线经纬度获取:http://www.gpsspg.com/maps.htm 仅供学习参考
转自:https://www.cnblogs.com/Zhusi/p/11470670.html
出处:https://www.iteye.com/blog/justcoding-2224906 上面有更多的计算方式
原文地址:https://www.cnblogs.com/yellowS/p/11909906.html
时间: 2024-10-02 21:05:10