附近的人计算方法-----使用mysql脚本计算方法
2016-04-21 00:00
453 查看
附近的人计算方法
drop functionif exists getDistance;
DELIMITER $$
CREATEDEFINER=`root`@`localhost`FUNCTION`getDistance`(
lon1float(10,7)
,lat1float(10,7)
,lon2float(10,7)
,lat2float(10,7)
)RETURNSdouble
begin
declareddouble;
declareradiusint;
setradius = 6378140; #假设地球为正球形,直径为6378140米
setd = (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;
returnd;
end
$$
DELIMITER ;
selectgetDistance(116.3899,39.91578,116.3904,39.91576);
drop functionif exists getDistance;
DELIMITER $$
CREATEDEFINER=`root`@`localhost`FUNCTION`getDistance`(
lon1float(10,7)
,lat1float(10,7)
,lon2float(10,7)
,lat2float(10,7)
)RETURNSdouble
begin
declareddouble;
declareradiusint;
setradius = 6378140; #假设地球为正球形,直径为6378140米
setd = (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;
returnd;
end
$$
DELIMITER ;
selectgetDistance(116.3899,39.91578,116.3904,39.91576);
相关文章推荐
- Mysql 地区经纬度 查询
- MYSQL函数编写一
- Mysql中创建索引的INDEX和KEY
- mysql 保存emoji 4字节宽度字符串
- MySQL索引
- Mysql中limit的用法详解
- mysql安装后中文插入不成功或者插入后乱码的问题
- MySQL数据库学习中的一些问题
- mysql+C#实战七:从界面输入记录
- 20150102--Mysql外键+增删改查-02
- 20150102--Mysql外键+增删改查-01
- Atlas读写分离Mysql集群的搭建
- mysql 5.6.20的安装、配置服务、设置编码格式
- 基准测试工具sysbench安装和使用
- MySQL应用并发优化实践
- 把远程MySQL数据库中的数据手工导入到本地MySQL数据库
- C3P0连接超时分析
- 为mysql 表重新设置自增的主键id
- Mysql日志管理
- 用MySQL创建数据库和数据库表