码迷,mamicode.com
首页 > 其他好文 > 详细

根据一个经纬度求几公里范围内的数据

时间:2017-09-08 18:12:56      阅读:303      评论:0      收藏:0      [点我收藏+]

标签:pre   不用   范围   cti   根据   转换   param   版本   解释   


/*
* *求两个已知经纬度之间的距离,单位为米 *@param lng1,lng2 经度 *@param lat1,lat2 纬度 *@return float 距离,单位米 **/ function getDistance($lng1,$lat1,$lng2,$lat2){ //将角度转为狐度 $radLat1=deg2rad($lat1);//deg2rad()函数将角度转换为弧度 $radLat2=deg2rad($lat2); $radLng1=deg2rad($lng1); $radLng2=deg2rad($lng2); $a=$radLat1-$radLat2; $b=$radLng1-$radLng2; $s=2*asin(sqrt(pow(sin($a/2),2)+cos($radLat1)*cos($radLat2)*pow(sin($b/2),2)))*6378.137*1000; return $s; } sql版:这里x是经度,Y是纬度 SELECT FORMAT(((6370996.81)*ACOS(COS( coordy2 *PI()/180) * COS({$y}*PI()/180) * COS(( coordx2 *PI()/180)-({$x}*PI()/180)) + SIN( coordy2 *PI()/180)*SIN( {$y} *PI()/180)))/1000,2) as distance

 

解释一下下

这里是两个版本,一个是封装的函数  一个是sql语句

在sql版本中,$x,$y因为是变量所以加了{},正式写的时候是不用加的

例如

技术分享

因为这里除以了1000,并且保留2为小数,如图:

技术分享

 

所以最后算下来是公里!如果想要米数,那么就把/1000去掉

 

例如:

技术分享

 

 

 

下边的例子调用:

 

技术分享

 

根据一个经纬度求几公里范围内的数据

标签:pre   不用   范围   cti   根据   转换   param   版本   解释   

原文地址:http://www.cnblogs.com/hopelooking/p/7495065.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!