Mysql 数据库,经纬度距离计算/经纬度范围检索 (谷歌方案)

Posted yellows

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql 数据库,经纬度距离计算/经纬度范围检索 (谷歌方案)相关的知识,希望对你有一定的参考价值。

技术图片
SELECT  
  id, (  
    6371 * acos (  
      cos ( radians(78.3232) )  
      * cos( radians( 数据库纬度字段) )  
      * cos( radians( 数据库经度字段) - radians(65.3234) )  
      + sin ( radians(78.3232) )  
      * sin( radians( 数据库纬度字段 ) )
     )
   ) AS distance
FROM 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 上面有更多的计算方式

 

以上是关于Mysql 数据库,经纬度距离计算/经纬度范围检索 (谷歌方案)的主要内容,如果未能解决你的问题,请参考以下文章

当经纬度为已知点时计算100米距离

根据经纬度和半径计算经纬度范围,根据两点经纬度计算距离

根据经纬度查询最近距离,mysql查询经纬度附近范围

根据圆形范围选择纬度和经度

mysql中怎么根据经纬度计算距离

Mysql 拿指定经纬度与数据库多条经纬度进行距离计算