当前位置:首页 > PHP > 正文内容

mysql查找附近的人,经纬度查询

陈杰5个月前 (11-04)PHP346

经纬度排序


mysql函数

CREATE DEFINER=`root`@`localhost` FUNCTION `get_distance`(`lon1` float,`lat1` float,`lon2` float,`lat2` float) RETURNS double

begin

declare d double;

declare radius int;

set radius = 6378140; #假设地球为正球形,直径为6378140米

set d = (2*ATAN2(SQRT(SIN((lat1-lat2)*PI()/180/2) 

*SIN((lat1-lat2)*PI()/180/2)+ 

COS(lat2*PI()/180)*COS(lat1*PI()/180) 

*SIN((lon1-lon2)*PI()/180/2) 

*SIN((lon1-lon2)*PI()/180/2)), 

SQRT(1-SIN((lat1-lat2)*PI()/180/2) 

*SIN((lat1-lat2)*PI()/180/2) 

+COS(lat2*PI()/180)*COS(lat1*PI()/180) 

*SIN((lon1-lon2)*PI()/180/2) 

*SIN((lon1-lon2)*PI()/180/2))))*radius;

return d;

END


原生用法

select * from test where get_distance(13.66667,24.61667,longitude,latitude)<500000000;


select get_distance(13.66667,24.61667,longitude,latitude) AS d from test ORDER BY d asc;


严格模式


CREATE DEFINER=`root`@`localhost` FUNCTION `get_distance`(`lon1` float,`lat1` float,`lon2` float,`lat2` float) RETURNS int(11)

READS SQL DATA

begin

declare d INT;

declare radius int;

set radius = 6378140; #假设地球为正球形,直径为6378140米

set d = (2*ATAN2(SQRT(SIN((lat1-lat2)*PI()/180/2) 

*SIN((lat1-lat2)*PI()/180/2)+ 

COS(lat2*PI()/180)*COS(lat1*PI()/180) 

*SIN((lon1-lon2)*PI()/180/2) 

*SIN((lon1-lon2)*PI()/180/2)), 

SQRT(1-SIN((lat1-lat2)*PI()/180/2) 

*SIN((lat1-lat2)*PI()/180/2) 

+COS(lat2*PI()/180)*COS(lat1*PI()/180) 

*SIN((lon1-lon2)*PI()/180/2) 

*SIN((lon1-lon2)*PI()/180/2))))*radius;

return d;

END;


扫描二维码至手机访问

扫描二维码推送至手机访问。

版权声明:本文由何烦过虎溪发布,如需转载请注明出处。

转载请注明出处:http://95shouyou.com/?id=10

分享给朋友:

相关文章

利用workerman实现webrtc实时音视频通话

利用workerman实现webrtc实时音视频通话

实现原理利用workerman的websocket实现实时消息传递。webrtc自带p2p功能,利用STUN中继服务器实现webrtc实时音视频看看我们的前端文件,只是一个单页面<html>...

laravel分表model映射的思路

预先估计会出现大数据量并且访问频繁的表,将其分为若干个表这种预估大差不差的,论坛里面发表帖子的表,时间长了这张表肯定很大,几十万,几百万都有可能。 聊天室里面信息表,几十个人在一起一聊一个晚上,时间长...

七牛云删除文件和批量删除文件

在项目中因为用到了七牛云的对象存储,价格公道,也降低我们的项目维护成本。但是在实际使用过程中,例如用户换了头像我们就需要删除用户之前的头像,以降低我们的存储成本。所以研究了一下七牛云的删除单个文件和批...

php对接支付宝转账到第三方接口实战

公司项目有一个用户钱包系统,用户创作的内容可以收到游客的打赏,当然就需要提现的接口了。最终选定的是支付宝转账接口,公司代收账户直接打款给用户绑定的支付宝账号,再也不用人工手动打款了。上代码准备好工具,...

Lumen框架报错Cannot declare class Event, because the name is already in use

Lumen框架报错Cannot declare class Event, because the name is already in use

Lumen框架报错信息Cannot declare class Event, because the name is already in use(1/1) ErrorExceptionCa...

通过代码创建多个同样的mysql表

在分库分表中可能要同时创建多个结构相同但后缀不同的表,通过代码实现for ($i = 3; $i <= 20; $i++) {    DB::connection('...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。