为了账号安全,请及时绑定邮箱和手机立即绑定

sql语句查询经纬度范围

sql语句查询经纬度范围

慕森卡 2019-03-20 18:21:35
最近在做查询指定经纬度范围的数据;问题不知如何下手,于是网上找了点资料,其中有些不懂的地方希望大家能给点想法!问题是这样的:sql语句查询经纬度范围指定一个经纬度,给定一个范围值(单位:千米),查出在经纬度周围这个范围内的数据。 经度:113.914619 纬度:22.50128 范围:2km longitude为数据表经度字段 latitude为数据表纬度字段 SQL在mysql下测试通过,其他数据库可能需要修改 SQL语句如下:select * from location where sqrt( ( ((113.914619-longitude)*PI()*12656*cos(((22.50128+latitude)/2)*PI()/180)/180) * ((113.914619-longitude)*PI()*12656*cos (((22.50128+latitude)/2)*PI()/180)/180) ) + ( ((22.50128-latitude)*PI()*12656/180) * ((22.50128-latitude)*PI()*12656/180) ) )<2其中的12656是啥意思啊,怎么来的呀?如果有大神整体解释下那就更好了!!
查看完整描述

4 回答

?
吃鸡游戏

TA贡献1829条经验 获得超7个赞

算一下球面两点距离就知道了,就是一个公式d(x1,y1,x2,y2)=r*arccos(sin(x1)*sin(x2)+cos(x1)*cos(x2)*cos(y1-y2))
加上距离的换算单位,自己就能知道那个值了

查看完整回答
反对 回复 2019-04-18
?
12345678_0001

TA贡献1802条经验 获得超5个赞

从语义来看应该是1经度(纬度)= 12656米。不过这只是近似值,尤其对经度来说,纬度越高的地方这个值越小,极端情况就是在极点为0。

这条sql的效率极低,需要扫描整张表。可以考虑使用空间索引,MySQL的话,可以了解下MySQL Spatial。MongoDB对空间数据的支持比较好,内置了GeoHash功能。


查看完整回答
反对 回复 2019-04-18
  • 4 回答
  • 0 关注
  • 1131 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信